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Preface 


Thank you very much for making use of TOSHIBA microcomputer LSIs and 
development systems. 

The TLCS-68000 family, including the TMP68000, is the general-purpose 16/32-bit 
microprocessor family which is developed by technical cooperation with Motorola Inc., 
and is compatible with the Motorola M68000 family. The TMP68000/10/08 have various 
features such as the general purpose 32-bit register set, the large linear address space, 
the powerful instruction set, and flexible addressing modes. The common 32-bit internal 
architecture is upward compatible with all the family MPUs. This manual describes 
overview of the architecture and function of each instruction set, which are requires for 
software development for each MPU (TMP68000/10/08) of TLCS-68000 family. Toshiba 
provides various microcomputer LSIs and its development system for wide range of 
application. 

No part of this manual may be transferred or reproduces without prior permission of 
Toshiba corporation. 
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1. ARCHITECTURAL DESCRIPTION 

1.1 INTRODUCTION 

The TMP68000, with a 16-bit data bus and 24-bit address bus, was only the first in a 
family of processors which implement a comprehensive, extensible computer 
architecture. It was soon followed by the TMP68008, with an 8-bit data bus and 20-bit 
address bus, by the TMP68010, which introduced the virtual machine aspects of the 
TLCS-68000 architecture. 

This manual is intended to serve as a programmer’s reference for both systems and 
applications programmers for four of the current implementations of the TLCS-68000 - 
the TMP68000, the TMP68008, the TMP68010. The hardware system design aspects of 
these processors, such as bus structure and control, are presented in the respective 
advance information data sheets for each device. 

The TMP68000 and the TMP68008 are identical from the view of the programmer, 
with the exception that the TMP68000 can directly access 16 megabytes (24 bits of 
address) and the TMP68008 can directly access 1 megabyte (20 bits of address). The 
TMP68010 have much in common with the first two devices but also possess some 
additional instructions and registers as well as full virtual machine/memory capability. 
Since the processors are so similar to the programmer, only the differences are 
highlighted. When the TLCS-68000 is referenced, the feature described is common to 
all. If a particular feature is applicable only to one processor, the TMP part number will 
be referenced. 

1.2 PROGRAMMER’S MODEL 

The TLCS-68000 executes instructions in one of two modes - user mode or supervisor 
mode. The user mode is intended to provide the execution environment for the majority 
of application programs. The supervisor mode allows some additional instructions and 
privileges and is intended for use by the operating system and other system software. 
See “4. EXCEPTION PROCESING” for further details. 

To provide for the upward compatibility of code written for a specific implementation 
of the TLCS-68000, the user programmer’s model is common to all implementations. 
The user programmer’s model is shown in Figure 1.1. 
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As shown in the user programmer's model, the TLCS-68000 offers 16 32-bit general 
purpose registers (D0~D7, AO'^AT), a 32-bit program counter, and an 8-bit condition 
code register. The first eight registers (D0"^D7) are used as data registers for byte (8- 
bit), word (16-bit), and long word (32-bit) operations. The second set of seven registers 
(A0~A6) and the stack pointer (USP) may be used as software stack pointers and base 
address registers. In addition, the address registers may be used for word and long word 
operations. All of the 16 registers may be used as index registers. 


31 16 15 8 7 0 
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Figure 1.1 User Programmer’s Model (TMP68000/TMP68008/TMP68010) 

The supervisor programmer’s model includes some supplementary registers in 
addition to the above mentioned registers. The TMP68000 and the TMP68008 contain 
identical supervisor mode register resources. These are shown in Figure 1.2 and include 
the status register (high order byte) and the supervisor stack pointer (A7’). 


31 16 15 0 

I-’-1 A7' 

I_^_I (SSP) SUPERVISOR STACK POINTER 

15 8 7 0 

I ! CCR I SR STATUS REGISTER 

Figure 1.2 Supervisor Programmer’s Model Supplement (TMP68000/TMP68008) 

The supervisor programming model supplement of the TMP68010 is shown in Figure 
1.3. In addition to the supervisor stack pointer and status register, it includes the vector 
base register and the alternate function code registers. 
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The vector base register is used to determine the location of the exception vector table 
in memory to support multiple vector tables. The alternate function code registers allow 
the supervisor to access user data space or emulate CPU space cycles. 
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Figure 1.3 Supervisor Programmer’s Model Supplement (TMP68010) 


The status register, shown in Figure 1.4, contains the interrupt mask (eight levels 
available) as well as the condition codes: overflow (V) , zero (Z), negative (N), carry(C), 
and extend (X). Additional status bits indicate that the processor is in a trace (T) 
mode and/or in a supervisor (S) state. 

Five basic data types are supported. These data types are: 

® Bits 

• BCD Digits (4 Bits) 

• Bytes (8 Bits) 

• Words (16 Bits) 

• Long Words (32 Bits) 

In addition, operations on other data types such as memory addresses, status word 
data, etc. are provided for in the instruction set. 


SYSTEM BYTE 


15 


13 


10 


4 


USER BYTE 


n 



Figure 1.4 Status Register 
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The 14 flexibe addressing modes, shown in Table 1.1, include six basic types: 

• Register Direct 

• Register Indirect 

• Absolute 

• Immediate 

• Program Counter Relative 

• Implied 

Included in the register indirect addressing modes is the capability to do 
postincrementing, predecrementing, offsetting, and indexing. Program counter relative 
mode can also be modified via indexing and offsetting. 


I 


Table 1.1 Data Addressing Modes 


Mode 

Generation 

Register Direct Addressing 

Data Register Direct 

Address Register Direct 

EA = Dn 

EA = An 

Absolute data Addressing 

Absolute Short 

Absolute Long 

EA = (Next Word) 

EA = (Next Two Words) 

Program Counter Relative Addressing 

Relative with Offset 

Relative with Index and Offset 

EA = (PC) + die 

EA = (PC) + (Xn) + d8 

Register Indirect Addresssing 

Register Indirect 

Postincrement Register Indirect 

Predecrement Register Indirect 

Register Indirect with Offset 

Indexed Register Indirect with Offset 

EA = (An) 

EA = (An), An<-An-t-N 

An^-An-N, EA = (An) 

EA = (An) + d16 

EA = (An) + (Xn) -j- d8 

Immediate Data Addressing 

Immediate 

Quick Immediate 

DATA = Next Word(s) 

Inherent Data 

Implied Addressing 

Implied Register 

EA = SR, USP, SSP, PC, 

VBR, SFC, DEC 


Notes: EA = 
An = 
Dn = 
Xn = 


Effective Address SR = Status Register 

Address Register PC = Program Counter 

Data Register ( ) = Contents of 

Address or Data Register 
used as Index Register 


d8 = 8-bit Offset (Displacement) 
dl6 = 16-bit Offset (Displacement) 

N = 1 for byte, 2 for word, and 4 for long word. 

. If An is the stack pointer and the operand 
size is byte, N = 2 to keep the stack pointer on a 
word boundary. 

4- =: Replaces 
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The TLCS-68000 instruction set is shown in Table 1.2. Some additional instructions 
are variations or subsets of these and they appear in Table 1.3. Special emphasis has 
been given to the instruction set’s support of structured high-level languages to 
facilitate ease of programming. Each instruction, with a few exceptions, operates on 
bytes, words, and long words and most instructions can use any of the 14 addressing 
modes. Combining instruction types, data types, and addressing modes, over 1000 
useful instructions are provided. These instructions include signed and unsigned 
multiply and divide, “quick” arithmetic operations, BCD arithmetic, and expanded 
operations (through traps). Additionally, its high-symmetric, proprietary microcoded 
structure provides a sound, flexible base for the future. 

1.3 SOFTWARE DEVELOPMENT 

Many innovative features have been incorporated to make programming easier, 
faster, and more reliable. 

1.3.1 Consistent Structure 

The highly regular structure of the TLCS-68000 greatly simplifies the effort required 
to write programs in assembly language as well as high-level languages. Operations on 
integer data in registers and memory are independent of the data. Separate special 
instructions that operate on byte (8 bit), word (16 bit), and long word (32 bit) integers are 
not necessary. The programmer need only remember one mnemonic for each type of 
operation and then specify data size,, source addressing mode, and destination 
addressing mode. This has helped keep the total number of instructions small. 

The dual operand nature of many of the instructions significantly increases the 
flexibility and power of the TLCS-68000. Consistency is again maintained since all data 
registers and memory locations may be either a source or destination for most operations 
on integer data. 

The addressing modes have been kept simple without sacrificing efficiency. All 
fourteen addressing modes operate consistently and are independent of the instruction 
operation itself. Additionally, all address registers may be used for the direct, register 
indirect, and indexed addressing modes (immediate, program counter relative, and 
absolute addressing by definition do not use address registers). For increased flexibility, 
any address or data register may be used as an index register. Address register 
consistency is maintained for stacking operations since any of the eight address 
registers may be utilized as user program stack pointers with the register indirect 
postincrement/predecrement addressing modes. Address register A7, however, is a 
special register that, in addition to is normal addressing capability, functions as the 
system stack pointer for stacking the program counter for subroutine calls as well as 
stacking the program counter and status register for traps and interrupts (while in the 
supervisor state). 
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Table 1.2 Instruction Set Summary (1/2) 


Mnemonic 

Description 

ABCD* 

Add Decimal with Extned 

ADD* 

Add 

AND* 

Logical AND 

ASL* 

Arithmetic Shift Left 

ASR* 

Arithmetic Shift Right 

Bcc 

Branch Conditionally 

BCHG 

Bit Test and Change 

BCLR 

Bit Test and Clear 

BKPT 

Breakpoint 

BRA 

Branch Always 

BSET 

BitTest and Set 

BSR 

Branch to Subroutine 

BIST 

Bit Test 

CHK 

Check Register Against Bounds 

CLR* 

Clear Operand 

CMP* 

Compare 

DBcc 

Decrement and Branch Conditionally 

DIVS 

Signed Divide 

DIVU 

Unsigend Divide 

EOR* 

Exclusive OR 

EXG 

Exchange Registers 

EXT 

Sign Extend 

JMP 

Jump 

JSR 

Jump to Subroutine 

LEA 

Load Effective Address 

LINK 

Link Stack 

LSL* 

Logical Shift Left 

LSR* 

Logical Shift Right 


* : These instructions available in loop mode on TMP68010. 

See “APPENDIX G TMP68010 LOOP MODE OPERATIONS”. 
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Table 1.2 Instruction Set Summary (2 / 2) 


Mnemonic 

Description 


Move Source to Destination 


Signed Multiply 

MULU 

Unsigned Multiply 

NBCD* 

Negate Decimal with Extend 

NEG* 

Negate 

NOP 

No Operation 

NOT* 

One's Complement 

OR* 

logical OR 

PEA 

Push Effective Address 

RESET 

Reset External Devices 

ROL* 

Rotate Left without Extend 

ROR* 

Rotate Right without Extend 

ROXL* 

Rotate Left with Extend 

ROXR* 

Rotate Right with Extend 

RTD 

Return and Deallocate 

RTE 

Return from Exception 

RTR 

Return and Restore 

RTS 

Return from Subroutine 

SBCD* 

Subtract Decimal with Extend 

See 

Set Conditional 

STOP 

Stop 

SUB* 

Subtract 

SWAP 

Swap Data Register Halves 

TAS 

Test and Set Operand 

TRAP 

Trap 

TRAPV 

Trap on Overflow 

TST* 

Test 

UNLK 

Unlink 
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Table 1.3 Variations of Instruction Types 


Instruction 

Type 

Variation 

Description 

ADD 

ADD* 

Add 


ADDA* 

Add Address 


ADDQ 

Add Quick 


ADDI 

Add Immediate 


ADDX* 

Add with extend 

AND 

AND* 

Logical AND 


ANDI 

AND Immediate 


ANDI to CCR 

AND Immediate to Condition Codes 


ANDI to SR 

AND Immediate to Status Regitster 

CMP 

CMP* 

Compare 


CMPA* 

Compare Address 


CMPM* 

Compare Memory 


CMPI 

Compare Immediate 

EOR 

EOR* 

Exclusive OR 


EORI 

Exclusive OR Immediate 


EORI to CCR 

Exclusive OR Immediate to Condition Codes 


EORI to SR 

Exclusive OR Immediate to Status Register 

MOVE 

MOVE* 

Move Source to Destination 


MOVEA* 

Move Address 


MOVEC 

Move Control Register 


MOVEM 

Move Multiple Registers 


MOVER 

Move Peripheral Data 


MOVEQ 

Move Quick 


MOVES 

Move Alternate Address Space 


MOVE from SR 

Move from Status Register 


MOVE to SR 

Move to Status Register 

1 

MOVE from CCR 

Move from Condition Codes 


MOVE to CCR 

Move to Condition Codes 


MOVE USP 

Move User Stack Pointer 

NEG 

NEG* 

Negate 


NEGX* 

Negate with Extend 

OR 

OR* 

Logical OR 


ORI 

OR Immediate 


ORI to CCR 

OR Immediate to Condition Codes 


ORI to SR 

OR Immediate to Status Register 

SUB 

SUB* 

Subtract 


SUBA* 

Subtract Add res 


SUBI 

Subtract Immediate 


SUBQ 

Subtract Quick 


SUBX* 

Subtract with Extend 


* These instructions available in loop mode on TMP68010. 

See ^‘APPENDIX G TMP68010 LOOP MODE OPERATIONS”. 
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1.3.2 Structured Modular Programming 

The art of programming microprocessors has evolved rapidly in the past few years. 
Numerous advanced techniques have been developed to allow easier, more consistent 
and reliable generation of software. In general, these techniques require that the 
programmer be more disciplined in observing a defined programming structure such as 
modular programming. Modular programming allows a required function or process to 
be broken down in short modules or subroutines that are concisely defined and easily 
programmed and tested. Such a technique is greatly simplified by the availability of 
advanced structured assemblers and block structured high-level languages such as 
Pascal, Such concepts are virtually useless, however, unless parameters are easily 
transferred between and within software modules that operate on a reentrant and 
recursive basis. (To be reentrant a routine must be usable by interrupt and non¬ 
interrupt driven programs without the loss of data. A recursive routine is one that may 
call or use itself.) The TLCS-68000 provides the necessary architectural features to 
allow efficient reentrant modular programming. The LINK and UNLK instructions 
reduce subroutine call overhead in two complementary instructions by allowing the 
manipulation of linked lists of data areas on the stack. The MOVEM (Move Multiple 
Register) instruction also reduces subroutine call programming overhead. This allows 
moving, via an effective address, multiple registers that are specified by the 
programmer. Sixteen software trap vector are provided with the TRAP instruction and 
are useful in operating system call routines or user generated macro routines. Other 
instructions that support modern structured programming techniques are PEA (Push 
Effective Address), LEA (Load Effective Address), RTR (Return and Restore), RTE 
(Return from Exception) as well as JSR (Jump to Subroutine), BSR (Branch to 
Subroutine), and RTS (Return from Subroutine). 

The powerful vectored priority interrupt structure of the microprocessor allows 
straight-foward generation of reentrant modular input/output routines. Seven 
maskable levels of priority with 192 vector locations and seven autovector locations 
provide maximum flexibility for I/O control (a total of 255 vector locations are available 
for interrupts, hardware traps, and software traps). 

1.3.3 Improved Software Testability 

The TLCS-68000 incorporates several features that reduce the chance for errors. 
Some of these features, such as consistent architecture and the structured modular 
programming capability, have already been discussed. 

Of major importance to the system programmer are features that have been 
incorporated specifically to detect the occurrence of programming errors or bugs. 
Several hardware traps, provided to indicate abnormal internal conditions, detect the 
following error conditions: 
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• Word Access with an Odd Address 

• Illegal Instructions 

• Unimplemented Instructions 

• Illegal Memory Access (Bus Error) 

• Divide by Zero 

• Overflow Condition Code (Separate Instruction TRAPV) 

• Register Out of Bounds (CHK Instruction) 

® Spurious Interrupt 

Additionally, the sixteen software TRAP instructions may utilized by the 
programmer to provide applications-oriented error detection or correction routines. 

An additional error detection tool is the CHK (Check Register Against Bounds) 
instruction used for array bound checking by verifying that a data register contains a 
valid subscript. A trap occurs if the register contents are negative or greater than a 
limit. 

Finally, the TLCS-68000 includes a facility that allows instruction-by-instruction 
tracing of a program being debugged. This trace mode results in a trap being made to a 
tracing routine after each instruction executed. The trace mode is available to the 
programmer when the microprocessor is in the supervisor state as well as the user state 
but may only be entered while in the supervisor state. The supervisor/user states 
provide an additional degree of error protection for the microprocessor by allowing 
memory protection of selected areas of memory when an external memory management 
device is used. 

1.4 VIRTUAL MEMQRY/MACHINE CONCEPTS 

The TMP68010 introduced the virtual memory/machine concept of the TLCS- 
68000 architecture. 

In most systems using the TMP68010 as the central processor, only a franction of 
the 16 megabyte address space will actually contain physical memory. However, by 
using virtual memory techniques the system can be made to appear to the user to 
have 16 megabytes of physical memory available. These techniqes have been used 
for several years in large mainframe computers and more recently in minicomputers 
and now, with the TMP68010, can be fully supported in microprocessor-based 
systems. 
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In a virtual memory system, a user program can be written as though it has a 
large amount of memory available to it when only a small amount of memory is 
physically present in the system. In a similar fashion, a system can be designed in 
such a manner as to allow user programs to access other types of devices that are not 
physically present in the system such as type drives, disk drives, printers, or CRTs. 
With proper software emulation, a physical system can be made to appear to a user 
program as any other computer system and the program may be given full access to 
all of the resources of that emulated system. Such an emulated system is called a 
virtual machine. 

1.4.1 Virtual Memory 

The basic mechanism for supporting virtual memory in computers is to provide 
only a limited amount of high-speed physical memory that can be accessed directly 
by the processor while maintaining an image of a much larger “virtual” memory on 
secondary storage devices such as large capacity disk drives. When the processor 
attempts to access a location in the virtual memory map that is not currently 
residing in physical memory (referred to as a page fault), the access to that location 
is temporarily suspended while the necessary data is fetched from the secondary 
storage and placed in physical memory; the suspended access is then completed. The 
TMP68010 provides hardware support for virtual memory with the capability of 
suspending an instruction’s execution when a bus error is signaled and then 
completing the instruction after the physical memory has been updated as 
necessary. 

The TMP68010 uses instruction continuation rather than instruction restart to 
support virtual memory. With instruction restart, the processor must remember the 
exact state of the system before each instruction is started in order to restore that 
state if a page fault occurs during its execution. Then, after the page fault has been 
repaired, the entire instruction that cauesd the fault is reexecuted. With instruction 
continuation, when a page fault occurs the processor stores its internal state and 
then after the page fault is repaired, restores that internal state and continues 
execution of the instruction. In order for the TMP68010 to utilize instruction 
continuation, it stores its internal state on the supervisor stack when a bus cycle is 
terminated with a bus error signal. It then loads the program counter from vector 
table entry number two (offset $008) and resumes program execution at that new 
address. When the bus error exception handler routine has completed execution, an 
RTE instruction is executed which reloads the TMP68010 with the internal state 
stored on the stack, re-runs the faulted bus cycle, and continues the suspended 
instruction. Instruction continuation has the additional advantage of allowing 
hardware support for virtual I/O devices. Since virtual registers may be simulated 
in the memory map, an access to such a register will cause a fault and the function of 
the register can be emulated by software. 
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1.4.2 Virtual Machine 

One typical use for a virtual machine system is in the development of software 
such as an operating system for another machine with hardware also under 
development and not available for programming use. In such a system, the 
governing operating system emulates the hardware of the new system and allows 
the operating system to be executed and debugged as though it were running on the 
new hardware. Since the new operating system is controlled by the governing 
operating system, the new one must execute at a lower privilege level than the 
governing operating system, so that any attempts by the new operating system to 
use virtual resources that are not physically present, and should be emulated, will 
be trapped by the governing operating system and handled in software. In the 
TMP68010, a virtual machine may be fully supported by running the new operating 
system in the user mode and the governing operating system in the supervisor mode 
so that any attempts to access supervisor resources or execute privileged 
instructions by the new operating system will cause a trap to the governing 
operating system. 

In order to fully support a virtual machine, the TMP68010 must protect the 
supervisor resources from access by user programs. The one supervisor resource 
that is not fully protected in the TMP68000 is the system byte of the status register. 
In the TMP68000 and TMP68008, the MOVE from SR instruction allows user 
programs to test the S bit (in addition to the T bit and interrupt mask) and thus 
determine that they are running in the user mode. For full virtual machine support, 
a new operating system must not be aware of the fact that it is running in the user 
mode and thus should not be allowed to access the S bit. For this reason, the MOVE 
from SR instruction has been added to allow user program unhindered access to the 
condition codes. By making the MOVE from SR instruction privileged, when the 
new operating system attempts to access the S bit, a trap to the governing operating 
system will occur, and the SR image passed to the new operating system by the 
governing operating system will have the S bit set. 
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2. DATA ORGANIZATION AND ADDRESSING CAPABILITIES 

2.1 INTRODUCTION 

This section describes the data organization and addressing capabilities of the TLCS- 
68000 architecture. 

2.2 OPERAND SIZE 

Operand sizes are defined as follows: a b 3 ^te equals 8 bits, a word equals 16 bits, and a 
long word equals 32 bits. The operand size for each instruction is either explicitly 
encoded in the instruction or implicitly defined by the instruction operation. All explicit 
instructions support byte, word, or long word operands. Implicit instructions support 
some subset of all three sizes. 

2.3 DATA ORGANIZATION IN REGISTERS 

The eight data registers support data operands of 1, 8, 16, or 32 bits. The seven 
address registers together with the active stack pointer support address operands of 32 
bits. 

2.3.1 Data Registers 

Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word 
operands the low order 16 bits, and long word operands the entire 32 bits. The least 
significant bit is addressed as bit zero; the most significant bit is addressed as bit 31. 

When a data register is used as either a source or destination operand, only the 
appropriate low order portion is changed; the remaining high-order portion is neither 
used nor changed. 

2.3.2 Address Registers 

Each address register and the stack pointer is 32-bits wide and holds a full 32 bit 
address. Address registers do not support byte sized operands. Therefore, when an 
address register is used as a source operand, either the low order word or the entire long 
word operand is used depending upon the operation size. When an address register is 
used as the destination operand, the entire register is affected regardless of the 
operation size. If the operation size is word, any other operands are sign extended to 32 
bits before the operation is performed. 
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2.4 DATA ORGANIZATION IN MEMORY 

Bytes are individually addressable with the high order byte having an even address 
the same as the word as shown in Figure 2.1. The low order byte has an odd address that 
is one count higher than the word address. Instructions and multibyte data are accessed 
only on word (even byte) boundaries. If a long word datum is located at address n(n 
even), then the second word of that datum is located at address n + 2. 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


WORD 000000 
BYTE 000000 | 

BYTE 000001 

WORD 000002 1 

BYTE 000002 

BYTE 000003 

1 


r_1 

_ 3 

WORD FFFFFE I 

1 BYTE FFFFFE | 

BYTE FFFFFF | 


Figure 2.1 Word Organization in Memory 


The data types supported by the TLCS-68000 are: bit data, integer data of 8, 16, and 
32-bit addresses, and binary coded decimal data. Each of these data types is put in 
memory as shown in Figure 2.2. The numbers indicate the order in which the data 
would be accessed from the processor. For convenience, the organization of data in 
memory for the TMP68008 is shown in Figure 2-3. The appearance to the programmer, 
however, is identical to the TMP68000, and TMP68010. 
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BIT DATA 
1 BYTE = 8 BITS 

7 6 5 4 3 2 1 0 


INTEGER DATA 
1 BYTE = 8 BITS 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



1 LONG WORD = 32 BITS 



ADDRESSES 
1 ADDRESS = 32 BITS 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


MSB 

- ADDRESS 0 


ADDRESS 1 


HIGH ORDER 
LOW ORDER 


LSB 


ADDRESS 2 


MSB = MOST SIGNIFICANT BIT 

LSB = LEAST SIGNIFICANT BIT DECIMAL DATA 


2 BINARY CODED DECIMAL DIGITS = 1 BYTE 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


MSD BCDO 

BCD1 LSD 

BCD2 

BCD3 

BCD4 

BCD5 

BCD6 

BCD7 


MSD = MOSTSIGNIFICANT DIGIT 
LSD = LEAST SIGNIFICANT DIGIT 


Figure 2.2 Data Organization In Memory 
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BIT DATA 1 BYTE = 8 BITS 
5 4 3 2 


INTEGER DATA 1 BYTE = 8 BITS 
5 4 3 2 


BYTEO 


BYTE 1 


BYTE 2 


BYTE 3 


1 WORD = 2 BYTES =16 BITS 


BYTE 0 (MS BYTE) 


BYTE 1 (LS BYTE) 

BYTE 2 (MS BYTE) 

\rt/r»Dn 1 

BYTE 3 (LS BYTE) 



LOWER ADDRESSES 


HIGHER ADDRESSES 


LOWER ADDRESSES 


HIGHER ADDRESSES 


1 LONG WORD = 2 WORDS = 4 BYTES = 32 BITS 


BYTEO 


HIGH ORDER 


BYTE 1 


BYTE 2 


LONG WORD 0 


WORD 


BYTE 3 
BYTEO 


LOW ORDER 
WORD 
HIGH ORDER 


BYTE 1 


BYTE 2 


LONG WORD 1 


WORD 
LOW ORDER 


BYTE 3 


WORD 


LOWER ADDRESSES 


HIGHER ADDRESSES 


Figure 2.3 Memory Data Organization of the TMP68008 
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2.5 ADDRESSING 

Instructions for the TLCS-68000 contain two kinds of information: the type of 
function to be performed and the location of the operand(s) on which to perform that 
function. The methods used to locate (address) the operand(s) are explained in the 
following paragraphs. 

Instructions specify an operand location in one of three ways: 

• Register Specification — the number of the register is given in the register field 

of the instruction. 

® Effective Address — use of the different effective address modes. 

• Implicit Reference — the definition of certain instructions implies the use of 

specific registers. 

2.6 INSTRUCTION FORMAT 

Instruction are from one to five words in length as shown in Figure 2.4. The length of 
the instruction and the operation to be performed is specified by the first word of the 
instruction which is called the operation word. The remaining words further specify the 
operands. These words are either immediate operands or extensions to the effective 
addres mode specified in the operation word. 

EVEN BYTES (AO = 0) ODD BYTES (AO = 1) I 

76543210176543210 I 

I 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

OPERATION WORD 

(FIRST WORD SPECIFIES OPERATION AND MODES) 

IMMEDIATE OPERAND (IF ANY, ONE OR TWO WORDS) 

SOURCE EFFECTIVE ADDRESS EXTENSION (IF ANY, ONE OR TWO WORDS) 

DESTINAATION EFFECTIVE ADDRESS EXTENSION 

IF ANY, ONE OR TWO WORDS) 

Figure 2.4 Instruction Format 

2.7 PROGRAM/DATA REFERENCES 

The TLCS-68000 separates memory references into two classes: program references 
and data references. Program references, as the name implies, are references to that 
section of memory that contains the program being executed. Data references refer to 
that section of memory that contains data. Generally, operand reads are from the data 
space. All operand writes are to the data space. 
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2.8 REGISTER NOTATION 

Appendix B contains a description of each instruction operation and identifies the 
registers using the following mnemonics: 

An — Address Register (n specifies the register number) 

Dn — Data Register (n specifies the register number) 

Xn — Any Register, Address or Data (n specifies the register number) 

PC — Program Counter 
SR — Status Register 

CCR — Condition Code Half of the Status Register 
SP — The Active Stack Pointer (either user or supervisor) 

USP — User Stack Pointer 
SSP — Supervisor Stack Pointer 
d8 — 8-bit Displacement Value 
dl6 — 16-bit Displacement Value 
disp “ Displacement Value (d8 or dl6) 

N “ Operand Size in Bytes (1,2,4) 

SFC, DEC — Source/Destination Function Code Register 
VBR “ Vector Base Register 

2.9 ADDRESS REGISTER INDIRECT NOTATION 

When an address register is used to point to a memory location, the addressing mode 
is called address register indirect. The term indirect is used because the operation of the 
instruction is not directed to the address itself, but to the memory location pointed to by 
the address register. The descriptive symbol for the indirect mode is an address register 
designation in parenthesis, i. e., (An). 

2.10 REGISTER SPECIFICATION 

The register field within an instruction specifies the register to be used. Other fields 
within the instruction specify whether the register selected is an address or data register 
and how the register is to be used. 

2.11 EFFECTIVE ADDRESS 

Most instructions specify the location of an operand by using the effective address 
field in the operation word. For example. Figure 2.5 shows the general format of the 
single effective address instruction operation word. The effective address is composed of 
two 3-bit fields: the mode field and the register field. The value in the mode field selects 
the different address modes. The register field contains the number of a register. 
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The effective address field may require additional information to fully specify the 
operand. This additional information, called the effective address extension, is 
contained in a following word or words and is considered part of the instruction as shown 
in Figure 2.4. The effective address modes are grouped into three categories: register 
direct, memory addressing, and special. 

EVEN BYTE i ODD BYTE I 

76543 2 1 0176 54 32 10 I 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

MODE 

EFFECTIVE ApDRESS 


Figure 2.5 Single-Effective-Address-Instruction Operation — General Format 

2.11.1 Register Direct Modes 

These effective addressing modes specify that the operand is in one of the 16 
multifunction registers. 

2.11.1.1 Data Register Direct 

The operand is in the data register specified by the effective address register field. 

GENERATION: EA = Dn 

ASSEMBLER SYNTAX : Dn 

MODE : 000 

REGISTER : n 

2.11.1.2 Address Register Direct 
The operand is in the address register specified by the effective address register field. 


DATA REGISTER Dn 


31 


OPERAND 


GENERATION : 
ASSEMBLER SYNTAX : 
MODE : 

REGISTER : 


EA = An 
An 
001 
n 


ADDRESS REGISTER An 


31_0 

I OPERAND 


2.11.2 Memory Address Modes 

These effective addressing modes specify that the operand is in memory and provide 
the sepcific address of the operand. 
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2.11.2.1 Address Register Indirect 

The address of the operand is in the address register specified by the register field. 
The reference is classified as a data reference with the exception of the jump and jump to 
subroutine instructions. 


GENERATION : 
ASSEMBLER SYNTAX: 
MODE : 

REGISTER ; 


EA = (An) 
(An) 

010 

n 


ADDRESS REGISTER An 

MEMORY ADDRESS 


31 0 



2.11.2.2 Address Register Indirect with Postincrement 

The address of the operand is in the address register specified by the register field. 
After the operand address is used, it is incremented by one, two, or four depending upon 
whether the size of the operand is byte, word, or long word. If the address register is the 
stack pointer and the operand size is byte, the address is incremented by two rather than 
one to keep the stack pointer on a word boundary. The reference is classified as a data 
reference. 


GENERATION : EA = (An) 

An = An + N 

ASSEMBLER SYNTAX ; (An) + 


MODE : 

Oil 


31 

0 

REGISTER : 

n 

ADDRESS REGISTER An 

MEMORY ADDRESS 



OPERAND LENGTH 

■ k- 




(1,2, or 4) 





MEMORY ADDRESS 

OPERAND 


2.11.2.3 Address Register Indirect with Predecrement 

The address of the operand is in the address register specified by the register field. 
Before the operand address is used, it is decremented by one, two, or four depending 
upon whether the operand size is byte, word, or long word. If the address register is the 
stack pointer and the operand size is byte, the address is decremented by two rather than 
one to keep the stack pointer on a word boundary. The reference is classified as a data 
reference. 
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GENERATION : 

ASSEMBLER SYNTAX: 
MODE : 

REGISTER : 


AA=An-N 
EA = (An) 

-(An) 

100 

n ADDRESS REGISTER An 

OPERAND LENGTH 
(1,2, or 4) 

MEMORY ADDRESS 


31 


0 



2.11.2.4 Address Register Indirect with Displacement 

This address mode requires one word of extension. The address of the operand is the 
sum of the address in the address register and the sign-extended 16-bit displacement 
integer in the extension word. The reference is classified as a data reference with the 
exception of the jump and jump to subroutine instructions. 


GENERATION : 
ASSEMBLER SYNTAX: 
MODE : 


En = (An) + d16 
die (An) 

101 


REGISTER : 


31 0 


ADDRESS REGISER An [ 

MEMORY ADDRESS 

15 0 

^ 1 

DISPLACEMENT | SIGN EXTENDED INTEGER 



T 

MEMORY ADDRESS [ 

OPERAND 


2.11.2.5 Address Register Inderect with Index 

This address mode requires one word of extension formatted as shown below. 


EVEN BYTE i ODD BYTE 

7654321 01765432 10 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


D/A 

REGISTER 

W/L 

0 

1 ° 

0 

DISPLACEMENT INTEGER 


Bit 15 - 

0 - 
1 - 
Bit 14-12 
Bit 11 - 

0 - 
1 - 


Index register indicator 
Data register 
Address register 
- Index register number 
Index size 

Sign-extended, low order integer in index register 
Long value in index register 


I 

I 


I 
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The address of the operand is the sum of the address in the address register, the sign- 
extended displacement integer in the low order eight bits of the extension word, and the 
contents of the index register. The reference is classified as a data reference with the 
exception of the jump and jump to subroutine instructions. The size of the index register 
does not affect the execution time of the instructions. 


GENERATION : En = (An) + (Xn)+d8 

ASSEMBLER SYNTAX : d8 (An, Xn.W) 


d8(An, Xn. 

MODE; 110 

REGISTER : n 

ADDRESS REGISTER 

DISPLACEMENT 

INDEX REGISTER 

MEMORY ADDRESS 


31 0 



OPERAND 


2.11.3 Special Address Modes 

The special address modes use the effective address register field to specify the special 
addressing mode instead of a register number. 

2.11.3.1 Absolute Short Address 


This address mode requires one word of extension. The address of the operand is in 
the extension word. The 16-bit address is sign extended before it is used. The reference 
is classified as a reference with the exception of the jump and jump to subroutine 


instructions. 

GENERATION : EA GIVEN 

ASSEMBLER SYNTAX : Abs.W 

MODE: 111 

REGISTER : 000 


EXTENSION 

WORD 

MEMORY ADDRESS 


15 
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2.11.3.2 Absolute Long Address 


The address mode requires two words of extension. The address of the operand is 
developed by the concatenation of the extension words. The high-order part of the 
address is the first extension word; the low order part of the address is the second 
extension word. The reference is classified as a data reference with the exception of the 
jump and jump to subroutine instructions. 


GENERATION : EA GIVEN 

ASSEMBLER SYNTAX : Abs.L 

MODE: 111 

REGISTER : 001 


FIRST EXTENSION WORD 

SECOND EXTENSION 
WORD 


MEMORY ADDRESS 


15 0 



2.11.3.3 Program Counter with Displacement 


This address mode requires one word of extension. The address of the operand is the 
sum of the address in the program counter and the sign-extended 16-bit displacement 
integer in the extension word. The value in the program counter is the address of the 
extension word. The reference is classifiedas a program reference. 


GENERATION: EA = {PC)+d16 

ASSEMBLER SYNTAX : d16 (PC) 


MODE : 


111 


REGISTER : 


010 


PROGRAM COUNTER 

EXTENSION 

WORD 

MEMORY ADDRESS 


31 0 
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2.11.3.4 Program Counter with Index 

This address mode requires one word of extension formatted as shown below. 

I EVEN BYTE i ODD BYTE 

I 76543210176543210 

* 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


D/A 

REGISTER 

W/L 

0 

0 

0 

DISPLACEMENT INTEGER 


Bit 15 - Index register indicator 

0 - Data register 
1 - Address register 
Bit 14through 12 - Index register number 

Bit 11 - Index size 

0 - Sign-extended, low order integer in index register 
1 - Long value in index register 


The address is the sum of the address in the program counter, the sign-extended 
displacement integer in the lower eight bits of the extension word, and the contents of 
the index register. The value in the program counter is the address of the extension 
word. This reference is classified as a program reference. The size of the index register 
does not affect the execution time of the instruction. 


GENERATION : 
ASSEMBLER SYNTAX: 


MODE : 
REGISTER : 


En=(PC) + (Xn) + d8 
d8 (PC, Xn.W) 
d8(PC, Xn.L) 

111 

Oil 


PROGRAM COUNTER 

EXTENSION WORD 

INDEX REGISTER 

MEMORY ADDRESS 


31 

0 

MEMORY ADDRESS 

7 0 

; t 

SIGN EXTENDED INTEGER 

1—© 

31/15 0 

1 \ 

SIGN EXTENDED INTEGER 

1—f 

31 

\ 0 

OPERAND 


2.11.3.5 Immediate Data 

This address mode requires either one.or two words of extension depending on the size 
of the operation. 


Byte Operation — operand is low order byte of extension word 
Word Operation — operand is extension word 

Long Word Operation — operand is in the two extension words, high order 16-bits are 
in the first extension word, low order 16 bits are in the 
second extension word. 
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GENERATION : 
ASSEMBLER SYNTAX; 
MODE : 

REGISTER : 


OPERAND GIVEN 
#<data> 

111 

100 


The extension word formats are shown below: 

EVEN BYTE | ODD BYTE 

76543210176543210 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



2.11.4 Effective Address Encoding Summary 

Table 2.1 is a summary of the effective addressing modes discussed in the previous 
paragraphs. 

Table 2.1 Effective Address Encoding Summary 


Addressing Mode 

Mode 

Register 

Data Regiser Direct 

000 

Register Number 

Address Register Direct 

001 

Register Number 

Address Register Indirect 

010 

Register Number 

Address Register Indirect with Postincrement 

oil 

Register Number 

Address Register Indirect with Predecrement 

100 

Register Number 

Address Register Indirect with Displacement 

101 

Register Number 

Address Register Indirect with Index 

110 

Register Number 

Absolute Short 

111 

000 

Absolute Long 

111 

001 

Program Counter with Displacement 

111 

010 

Program Counter wiht Index 

111 

oil 

Immediate 

111 

100 
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2.12 IMPLICIT REFERENCE 

Some instructions make implicit reference to the program counter (PC), the system 
stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or 
the status register (SR). Table 2.2 provides a list of these instructions and the registers 
implied. 


Table 2.2 Implicit Instruction Reference Summary 


Instruction 

Implied Register(s) 

Branch Conditional (Bcc), Branch Always (BRA) 

PC 

Branch to Subroutine (BSR) 

PC, SP 

Check Register Against Bounds (CHK) 

SSP, SR 

Test Condition, Decrement and Branch (DBcc) 

PC 

Signed Divide (DIVS) 

SSP, SR 

Unsigned Divide (DIVU) 

SSP, SR 

Jump (JMP) 

PC 

jump to Subroutine (JSR) 

PC, SP 

Link and Allocate (LINK) 

PC, SP 

Move Condition Codes (MOVE CCR) 

SR 

Move Control Register (MOVEC) 

VBR, SFC, DFC 

Move Alternate Address Space (MOVES) 

SFC, DFC 

Move Status Register (MOVE SR) 

SR 

Move User Stack Pointer (MOVE USP) 

USP 

Push Effective Address (PEA) 

SP 

Return and Deallocate (RTD) 

PC, SP 

Return from Exception (RTE) 

PC, SP, SR 

Return and Restore Condition Codes (RTR) 

PC, SP, SR 

Return from Subroutine (RTS) 

PC, SP 

Trap (TRAP) 

SSP, SR 

Trap on Overflow (TRAPV) 

SSP, SR 

Unlink (UNLK) 

SP 

Logical Immediate to CCR 

SP 

Logical Immediate to SR 

SP 
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2.13 STACK AND QUEUES 

In addition to supporting the array data structure with the index addressing mode, 
the TLCS-68000 also supports stack and queue data structures with the address register 
indirect postincrement and predecrement addressing modes. A stack is a last-in-first¬ 
out (LIFO) list, a queue is a first-in-first-out (FIFO) list. When data is added to a stack 
or queue, it is “pushed” onto the structure; when it is removed, it is “pulled” from the 
structure. 

The system stack is used implicitly by many instructions; user stacks and queues may 
be created and maintained through the addressing modes. 

2.13.1 System Stack 

Address register seven (A7) is the system stack pointer (SP). The system stack 
pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), 
depending on the state of the S bit in the status register. If the S bit indicates supervisor 
state, the SSP is the active system stack pointer and the USP cannot be referenced as an 
address register. If the S bit indicates user state, the USP is the active system stack 
pointer and the SSP cannot be referenced. Each system stack fills from high memory to 
low memory. The address mode — (SP) creates a new item on the active system stack 
and the address mode (SP) -f deletes an item from the active system stack. 

The program counter is saved on the active system stack on subroutine calls and 
restored from the active system stack on returns. On the other hand, both the program 
counter and the status register are saved on the supervisor stack during the processing 
of traps and interrupts. Thus, the correct execution of the supervisor state code is not 
dependent on the behavior of user code and user programs may use the user stack 
pointer arbitrarily. 

In order to keep data on the system stack aligned properly, data entry on the stack is 
restricted so that data is always put in the stack on a word boundary. Thus, byte data is 
pushed on or pulled from the system stack in the high half of the word; the lower half is 
unchanged. 

2.13.2 User Stacks 

User stacks can be implemented and manipulated by employing the address register 
indirect with postincrement and predecrement addressing modes. Using an address 
register (one of A0~A6), the user may implement stacks which are filled either from 
high memory to low memory, or vice versa. The important things to remember are: 
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• using predecrement, the register is decremented before its contents are used as the 
pointer into the stack; 

• using postincrement, the register is incremented after its contents are used as the 
pointer into the stack; 

• byte data must be put on the stack in pairs when mixed with word or long data so that 
the stack will not misaligned when the data is retrieved. Word and long accesses 
must be on word boundary (even) addresses. 

Stack growth from high to low memory is implemented with 
— (An) to push data on the stack, 

(An) + to pull data from the stack. 

After either a push or a pull operation, register An points to the last (top) item on the 
stack. This is illustrated as: 



LOW MEMORY 

(FREE) 

TOP OF STACK 


- * Z 

BOTTOM OF STACK 

HIGH MEMORY 


Stack growth from low to high memory is implemented with 
(An) + to push data on the stack, 

— (An) to pull data from the stack. 

After either a push or a pull operation, register An points to the next available space 
on the stack. This is illustrated as: 



LOWMEMEORY 


BOTTOM OF STACK 

- 

; :: 


TOP OF STACK 


(FREE) 


HIGH MEMORY 
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2.13.3 Queues 

User queues can be implemented and mainpulated with the address register indirect 
with postincrement or predecrement addressing modes. Using a pair of address 
registers (two of A0~A6), the user may implement queues which are filled either from 
high memory to low memory, or vice versa. Because queues are pushed from one end 
and pulled from the other, two registers are used: the put and get pointers. 

Queue growth from low to high memory is implemented with 
(An) + to put data into the queue, 

(Am) + to get data from the queue 

After a put operation, the put address register points to the next available space in 
the queue and the unchanged get address register points to the next item to remove from 
the queue. After a get operation, the get address register points to the next item to 
remove from the queue and the unchanged put address register points to the next 
available space in the queue. This is illustrated as: 



If the queue is to be implemented as a circular buffer, the address register should be 
checked and, if necessary, adjusted before the put or get operation is performed. The 
address register is adjusted by subtracting the buffer length (in bytes). 

Queue growth from high to low memory is implemented with 

— (An) : to put data into the queue, 

— (Am): to get data from the queue 

After a put operation, the put address register points to the last item put in the queue 
and the unchanged get address register points to the last item removed from the queue. 
After a get operation, the get address register points to the last item removed from the 
queue and the unchanged put address register points to the last item put in the queue. 
This is illustrated as: 
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If the queue is to be implemented as a circular buffer, the get or put operation should 
be performed first, and then the address register should be checked and, if necessary, 
adjusted. The address register is adjusted by adding the buffer length (in bytes). 
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3. INSTRUCTION SET SUMMARY 

3.1 INTRODUCTION 


This section contains an overview of the TLCS-68000 architecture instruction set. 
The instructions from a set of tools to perform the following operations: 


Data Movement 
Integer Arithmetic 
Logical 

Shift and Rotate 
Bit Manipulation 


Bit Field Manipulation 
Binary Coded Decimal Arithmetic 
Program Control 
System Control 

Multiprocessor Communications 


The complete range of instruction capabilities combined with the flexible addressing 
modes described previously provide a very flexible base for program development. 
Detailed information about each instruction is given in Appendix B. 


Instructions available only on the TMP68010 or which behave differently on the 
TMP68010 are highlighted. 

The following notations will be used throughout this section. 


An 

Dn 

Xn 

CCR 

cc 

SP 

USP 

SSP 

DFC 

SFC 

Rc 

d8 

dl6 

disp 

<ea> 

list 

# <data> 
label 
[7] 
[31:24] 
X 
N 
Z’ 


any address register, A0-A7 
any data register, D0-D7 
any address or data register 

condition code register (lower byte of status register) 

condition codes from CCR 

active stack pointer 

user stack pointer 

supervisor stack pointer 

destination function code register 

source function code register 

control register (VBR, SFC, DFC) 

8-bit displacement 

16-bit displacement 

d8 or dl6 

effective address 

list of registers, e.g., D0-D3 

immediate data; a literal integer 

assemby program label 

bit 7 of respective operand 

bits 31~ 24 of operand; i.e., high order byte of a register 
extend (X) bit in CCR 
negative (N) bit in CCR 
zero (Z) bit in CCR 
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= invert; operand is logically complemented 
A = logical AND 
V = logical OR 
0 = logical exclusive OR 

3.2 DATA MOVEMENT OPERATIONS 

The basic means of address and data manipulation (transfer and storage) is 
accomplished by the move (MOVE) instruction and its associated effective addressing 
modes. Data movement instructions allow byte, word, and long word operands to be 
transferred from memory to memory, memory to register, register to memory, and 
register to register. Address movement instructions (MOVE or MOVEA) allow word 
and long word operand transfers to ensure that only legal address manipulations are 
executed. In addition to the general MOVE instruction there are several data 
movement instructions: move multiple registers (MOVEM), move peripheral data 
(MOVER), move quick (MOVEQ), exchange registers (EXG), load effective address 
(LEA), push effective address (PEA), link stack (LINK), unlink stack(UNLK). Table 3.1 
is a summary of the data movement operations. 
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Table 3.1 Data Movement Operations 


Instruction 

Operand Size 

Operation 

EXG 

32 

Xn-^Xn 

LEA 

32 

<ea>-^An 



An-» -(SP) 

LINK 

- 

SP->An 



SP + d16-^SP 

MOVE 

8, 16, 32 

(<ea>)-><ea> 

MOVEA 

16, 32 

(<ea>)-^An 

MOVEC 

32 

Xn-^Rc 



Rc-^Xn 

MOVEM 

16, 32 

(<ea>)—>An, Dn 

An, Dn-^<ea> 

MOVES 

8, 16, 32 

(<ea>)^Xn 

Xn-><ea> 

MOVER 

16, 32 

(<ea>)—>Dn 

Dn-^<ea> 

MOVEQ 

8 

#<data>->Dn 

PEA 

32 

<ea>^ - (SP) 

SWAP 

32 

Dn[31:16]«-Dn[15:0] 

UNLK 

- 

An->SP 



(SP) + -^An 


3.3 INTEGER ARITHMETIC OPERATIONS 

The arithmetic operations include the four basic operations of add (ADD), subtract 
(SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP, CMPM), 
clear (CLR), and negate (NEG). The ADD, CMP, and SUB instructions are available for 
both address and data operations, with data operations accepting all operand sizes. 
Address operations are limited to legal address size operands (16 or 32 bits). The clear 
and negate instructions may be used on all sizes of data operands. 

The MUL and DIV operations are available for signed and unsigned operands using 
word multiply to produce a long word product, and a long word dividend with word 
divisor to produce a word quotient with a word remainder. 

Multiprecision and mixed size arithmetic can be accomplished using a set of extended 
instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), 
sign extend (EXT), and negate binary with extend (NEGX). 
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Refer to Table 3.2 for a summary of the integer arithmetic operations. 


Table 3.2 Integer Arithmetic Operations 


Instruction 

Operand Size 

Operation 

ADD 

8, 12, 32 

Dn + (<ea>)->Dn 
(<ea>) + Dn-><ea> 

(<ea>) ■t-#<data>-^<ea> 

ADDA 

16, 32 

An +(<ea>)->An 

ADDX 

8, 16, 32 

Dx + Dy + X-^Dx 


16, 32 

- (An) + - (An) + X-^(An) 

CLR 

8, 16, 32 

0-^<ea> 

CMP 

8, 16, 32 

Dn -(<ea>) 

(EA) - #<data > 

(Ax) + - (Ay) + 

CMPA 

16, 32 

An -(<ea>) 

DIVS 

32-f 16 

Dn 4-(<ea>)->Dn 

DIVU 

32 4-16 

Dn 4-(<ea>)->Dn 

EXT 

8-^16 

(Dn)8->Dn16 


16-^32 

(Dn)16^Dn32 

MULS 

16x 16-^32 

Dn x(<ea>)->Dn 

MULU 

16x16^32 

Dn x(<ea>)->Dn 

NEG 

8, 16, 32 

0 - (<ea>)—>Dn 

NEGX 

8, 16, 32 

0-(<ea>)-X—><ea> 

SUB 

8, 16, 32 

Dn - (<ea>)-^Dn 
(<ea>) - Dn-^<ea> 

(<ea>) -#<data>-><ea> 

SUBA 

16, 32 

An -(<ea>)->An 

SUBX 

8, 16, 32 

Dx - Dy - X-^Dx 
-(Ax)- -(Ay)-X^(Ax) 

TAS 

8 

(<ea>)-0, 1->EA[7] 

TST 

8, 16, 32 

(<ea>) -0 
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3.4 LOGICAL OPERATIONS 

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of 
integer data operands. A similar set of immediate instructions (ANDI, ORI, EOR, and 
EORI) provide these logical operations with all sizes of immediate data. TST is an 
arithmetic comparison of the operand with zero which is then reflected in the condition 
codes. Table 3.3 is a summary of the logical operations. 


Table 3,3 Logical Operations 


Instruction 

Operand 

Size 

Operation 

AND 

8, 16, 32 

DnA(<ea>) ->Dn 
(<ea>) ADn -><ea> 

(<ea>) A#<data> <ea> 

OR 

8, 16, 32 

Dnv(<ea>) ->Dn 
(<ea>) vDn <ea> 

(<ea>) v#<data> -> <ea> 

EOR 

8, 16, 32 1 

! 

(<ea>) ©Dn —> <ea> 

(<ea>) ©#<data> ^ <ea> 

NOT 

8, 16, 32 * 

~ (<ea>) —^ <ea> 


3.5 SHIFT AND ROTATE OPERATIONS 

Shift operations in both directions are provided by the arithmetic shift instructions 
ASR and ASL, and logical shift instruction LSR and LSL. The rotate instructions (with 
and without extend) available are ROR, ROL, ROXR, and ROXL. 

All shift and rotate operations can be performed on either registers or memory. 

Register shifts and rotates support all operand sizes and allow a shift count (from one 
to eight) to be specified in the instruction operation word or a shift count (modulo 64) to 
be specified in a register. 

Memory shifts and rotates are for word operands only and allow only single-bit shifts 
or rotates. The SWAP instruction exchanges the 16-bit halves of a register. 
Performance of shift/rotate instructions is enhanced so that use of the ROR or ROL 
instructions with a shift count of eight allows fast byte swapping. 
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3.6 BIT MANIPULATION OPERATIONS 

Bit manipulation operations are accomplished using the following instructions: bit 
test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change 
(BCHG). All bit manipulation operations can be performed on either registers or 
memory, with the bit number specified as immediate data or by the contents of a data 
register. Register operands are always 32-bits, while memory operands are always 8 
bits. Table 3.5 is a summary of the bit manipulation operations. (Z is bit 2, the “zero” 
bit, of the status register.) 


Table 3.5 Bit Manipulation Operations 


Instruction 

Operand Syntax 

Operation 

BTST 

8, 32 

(<Bit Number>of Destination)->Z 

BSET 

8, 32 

(<Bit Nunnber>of Destination) 

-»Z;1-»Bit of Destination 

BCLR 

8, 32 

~ (<Bit Number>of Destination) 

-^Z;0->Bit of Destination 

BCHG 

8, 32 

~ (<Bit Number>of Destination) 

^Z->Bit of Destination 
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3.7 BINARY CODED DECIMAL OPERATIONS 

Multiprecision arithmetic operations on binary coded decimal numbers are 
accomplished using the following instructions: add decimal with extend (ABCD), 
subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 
3.6 is a summary of the binary coded decimal operations. 


Table 3.6 Binary Coded Decimal Operations 


Instruction 

Operand Size 

Operation 

ABCD 

8 

Dxio+ Dyio+ X->Dx 
-(Ax)io + “(Ay)io + X-»(Ax) 

SBCD 

8 

Dxio - Dyio - X-^Dx 
-(Ax)io - -(Ay)io - X^(Ax) 

NBCD 

8 

0 - (<ea>)io - X-^<ea> 


3.8 PROGRAM CONTROL OPERTIONS 

Program control operations are accomplished using a set of conditional and 
unconditional branch instructions and return instructions. These instructions are 
summarized in Table 3.7. 
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Table 3.7 Prpogram Control Operations 


Instruction 

Operation 

Conditional 

Bcc 

If Condition True, Then PC + dlsp-->PC 

DBcc 

If Condition False, Then Dn - 1-»Dn 
lfDn=!t -1,Then PC + d16->PC 

See 

If Condition True, Then Vs-^Destlnation; 

Else O's^Destination 

Unconditional 

BRA 

BSR 

JMP 

JSR 

NOP 

PC + disp^PC 

SP-4^SP; PC->(SP); PC + disp-^PC 

Destination-^PC 

SP-4->SP; PC-^(SP); Destinaiton-^PC 

PC + 2->PC 

Returns 

RTD 

RTR 

RTS 

(SP)^PC; SP + 4 + d16^SP 

(SP)^CCR; SP + 2^SP; (SP)-»PC; SP + 4^SP 

(SP)->PC; PC + 4^SP 


The conditional instructions provide testing and branching for the following 
conditions: 


CC — carry clear 
CS — carry set 
EQ — equal 
F — never true* 

GE — greater or equal 
GT — greater than 
HI - high 
LE — less or equal 


LS low or same 
LT — less than 
MI — minus 
NE — not equal 
PL — plus 
T — always true* 
VC — overflow clear 
VS — overflow set 


* : Not available for the Bcc instructions; use BRA for T and NOP for F. 

3.9 SYSTEM CONTROL OPERATIONS 

System control oprations are accomplished by using privileged instructions, trap 
generating instructions, and instructions that use or modify the condition code register. 
These instructions are summarized in Table 3.8. In the TMP68010, the MOVE from SR 
instruction has been made privileged and the MOVE from CCR has been added. For 
more detail see “1.4 VIRTUAL MEMORY/MACHINE CONCEPTS”. 
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Table 3.8 System Control Operations 


Instruction 

Operation 

Privilleged 


ANDI to SR 

Immediate Data A SR—>SR 

EORI to SR 

Immediate Data0 SR^SR 

ORI to SR 

Immediate Data V SR->SR 

MOVE EA to SR 

Source-^SR 

MOVE SR to EA 

SR-^Destination 

MOVE USP 

USP-^An 

An-^USP 

MOVEC 

Rc-^Xn 

MOVES 

Xn-^Rc 

Xn—>Destination Using DEC 

Source Using SFC-^Xn 

RESET 

Assert RESET line 

RTE 

(SP)^SR; SP + 2^SP; (SP)^PC; SP + 4^SP; 

Restore Stack According to Format 

STOP 

Immediate Data-^SR; STOP 

Trap Generating 


TRAP 

SSP-2->SSP; Format and Vector OFfset-^(SSP); ... 

SSP - 4->SSP; PC-^(SSP);SSP - 2->SSP; 

SR^(SSP); Vector Address-^PC 

TRAPV 

If V Then Take Overflow TRAP Exception 

CHK 

If Dn<0 or Dn>(ea),Then CHK Exception 

BKPT 

Execute Breakpoint Acknowiedge Bus Cycle; ... 

Trap as illegal Instsruction 

ILLEGAL 

SSP - 2->SSP; Vector Offset-^(SSP); ... 

SSP-4-^SSP; PC-^(SSP); 

SSP-2^SSP; SR^(SSP); 

Illegal Instruction Vector Address-^PC 

Condition Code 

Register 


ANDI to CCR 

Immediate Data A CCR->CCR 

EORI to CCR 

Immediate Data© CCR->CCR 

ORI to CCR 

Immediate Data V SR^SR 

MOVE EA to CCR 

Source^CCR 

MOVE CCR to EA 

CCR->Destination 


VMPU-39 




TOSHIBA 


TLCS-68000 


3.10 MULTIPROCESSOR OPERATIONS 

Communication between the TLCS-68000 Family of microprocessors is supported by 
the TAS instruction which executes indivisible read-modify-write bus cycles. See Table 
3.9. 


Table 3.9 Multiprocessor Operations 


Instruction 

Operand 

Size 

Operation 

TAS 

8 

Destination -0; Set Condition Codes; 1—^Destination (7) 
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4. EXCEPTION PROCESSING 

4.1 INTRODUCTION 

This section describes the actions of the TLCS-68000 which are outside the 
normal processing associated with the execution of instructions. The functions of 
the bits in the supervisor portion of the status register are covered: the 
supervisor/user bit, the trace enable bit, and the processor priority mask. Finally, 
the sequence of memory references and actions taken by the processor on exception 
conditions is detailed. 

The processor is always in one of three processing states: normal, exception, or 
halted. The normal processing state is that associated with instruction execution; 
the memory references are to fetch instructions and operands, and to store results. A 
special case of the normal state is the stopped state which the processor enters when 
a STOP instruction is executed. In this state, no further memory references are 
made. 

An additional special case of the normal state exists in the TMP68010, the loop 
mode, which may be entered when a DBcc instruction is executed. In loop mode, 
only operand fetches occur. See “APPENDIX G TMP68010 LOOP MODE 
OPERATION”. 

The exception processing state is associated with interrupts, trap instructions, 
tracing, and other exceptional conditions. The exception may be internally 
generated by an instruction or by an unusual condition arising during the execution 
of an instruction. Externally, exception processing can be forced by an interrupt, by 
a bus error, or by a reset. Exception processing is designed to provide an efficient 
context switch so that the processor may handle unusual conditions. 

The halted processing state is an indication of catastrophic hardware failure. For 
example, if during the exception processing of a bus error another bus error occurs, 
the processor assumes that the system is unusable and halts. Only an external reset 
can restart a halted processor. Note that a processor in the stopped state is not in the 
halted state, nor vice versa. 

4.2 PRIVILEGE STATES 

The processor operates in one of two states of privilege: the user state or the 
supervisor state. The privilege state determines which operations are legal, is used 
by the external memory management device to control and translate accesses, and is 
used to choose between the supervisor stack pointer and the user stack pointer in 
instruction references. 

The privilege state is a mechanism for providing security in a computer system. 
Programs should access only their own code and data areas and ought to be 
restricted from accessing information which they do not need and must not modify. 
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The privilege mechanism provides security by allowing most programs to execute 
in user state. In this state, the accesses are controlled and the effects on other parts 
of the system are limited. The operating system executes in the supervisor state, has 
access to all resources, and performs the overhead tasks for the user state programs. 

4.2.1 Supervisor State 

The supervisor state is the higher state of privilege. For instruction execution, 
the supervisor state is determined by the S bit of the status register; if the S bit is 
asserted (high), the processor is in the supervisor state. All instructions can be 
executed in the supervisor state. The bus cycles generated by instructions executed 
in the supervisor state are classified as supervisor references. While the processor is 
in the supervisor privilege state, those instructions which use either the system 
stack pointer implicitly or address register seven explicitly access the supervisor 
stack pointer. 

All exception processing is done in the supervisor state, regardless of the state of 
the S bit when the exception occurs. The bus cycles generated during exception 
processing are classified as supervisor references. All stacking operations during 
exception processing use the supervisor stack pointer. 

4.2.2 User State 

The user state is the lower state of privilege. For instruction execution, the user 
state is determined by the S bit of the status register; if the S bit is negated (low), the 
processor is executing instructions in the user state. 

Most instructions execute identically in user state and in the supervisor state. 
However, some instructions which have important system effects are mode 
privilege. User programs are not permitted to execute the STOP instruction or the 
RESET instruction. To ensure that a user program cannot enter the supervisor state 
except in a controlled manner, the instructions which modify the whole status 
register are privileged. To aid in debugging programs which are to be used as 
operating systems, the move to user stack pointer (MOVE to USP) and move from 
user stack pointer (MOVE from USP) instructions are also privileged. 

To implement virtual machine concepts in the TMP68010, the move from status 
register (MOVE from SR), move to/from control register (MOVEC), and move 
alternate address space (MOVES) instructions are also privileged. 

The bus cycles generated by an instruction executed in user state are classified as 
user state references. This allows an external memory management device to 
translate the address and the control access to protected portions of the address 
space. While the processor is in the user privilege state, those instructions which 
use either the system stack pointer implicitly or address register seven explicitly 
access the user stack pointer. 
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4.2.3 Privilege State Changes 

Once the processor is in the user state and executing instructions, only exception 
processing can change the privilege state. During exception processing, the current 
state of the S bit of the status register is saved and the S bit is asserted, putting the 
processor in the supervisor state. Therefore, when instruction execution resumes at the 
address specified to process the exception, the processor is in the supervisor privilege 
state. 

The transition from supervisor to user state can be accomplished by any of four 
instructions: return from exception (RTE), move to status register (MOVE word to SR), 
AND immediate to status register (ANDI to SR), and exclusive OR immediate to status 
register (EORI to SR). The RTE instruction fetches the new status register and program 
counter from the supervisor stack, loads each into its respective register, and then 
begins the instruction fetch at the new program counter address in the privilege state 
determined by the S bit of the new contents of the status register. The MOVE, ANDI, 
and EORI to status register instructions each fetch all operands in the supervisor state, 
perform the appropriate update to the status register, and then fetch the next 
instruction at the next sequential program counter address in the privilege state 
determined by the new S bit. 

4.2.4 Reference Classification 

When the processor makes a reference, it classifies the kind of reference being made, 
using the encoding of the three function code output lines. This allows external 
translation of addresses, control of access, and differentiation of special processor states, 
such as interrupt acknowledge. Table 4.1 lists the classification of references. 

Table 4.1 Reference Classification 


Function Code Output 

Address Space 

FC2 

FC1 

FCO 

Low 

Low 

Low 

(Undefined, Reserved) 

Low 

Low 

High 

User Data 

Low 

High 

Low 

User Program 

Low 

High 

High 

(Undefined, Reserved) 

High 

Low 

Low 

(Undefined, Reserved) 

High 

Low 

High 

Supervisor Data 

High 

High 

Low 

Supervisor Program 

High 

High 

High 

Interrupt Acknowledge 
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4.3 EXCEPTION PROCESSING 

Before discussing the details of interrupts, traps, and tracing, a general 
description of exception processing is in order. The processing of an exception occurs 
in four steps, with variations for different exception causes. During the first step, a 
temporary copy of the status register is made and the status register is set exception 
processing. In the second step the exception vector is determined and the third step 
is the saving of the current processor context. In the fourth step a new context is 
obtained and the processor switches to instruction processing. 

4.3.1 Exception Vectors 

Exception vectors are memory locations from which the processor fetches the 
address of a routine which will handle that exception. All exception vectors are two 
words in length (Figure 4.1) except for the reset vector, w’-hich is four words. All 
exception vectors lie in the supervisor data space except for the reset vector which is 
in the supervisor program space. A vector number is an 8-bit number which, when 
multiplied by four, gives the offset of an exception vector. Vector numbers are 
generated internally or externally, depending on the cause of the exception. In the 
case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides 
an 8-bit vector number (Figure 4.2) to the processor on data bus lines D0~D7. 

The processor forms the vector offset by left-shifting the vector number two bit 
positions and zero-filling the upper order bits to obtain a 32-bit long word vector 
offset. In the case of the TMP68000 and TMP68008, this offset is used as the 
absolute address to obtain the exception vector itself. This is shown in Figure 4.3. 

In the case of the TMP68010/TMP68012, the vector offset is added to the 32-bit 
vector base register (VBR) to obtain the 32-bit absolute address of the exception 
vector. This is shown in Figure 4.4. Since the VBR is set to zero upon reset, the 
TMP68010, will function identically to the TMP68000 and TMP68008 until the VBR 
is changed via the MOVEC instruction. 

EVEN BYTES (AO = 0) _|_ ODD BYTES (AO = 1) 

WORD 0 _ NEW PROGRAM COUNTER (HIGH) _A1 =0 

WORD 1 _ NEW PROGRAM COUNTER (LOW) _A1 = 1 

Figure 4.1 Exception Vector Format 
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D15 D8 D7 DO 


IGNORED 

V7 

V6 

V5 

V4 

V3 

V2 

VI 

VO 


where: 

V? is the MSB of the vector number 
VO is the LSB of the vector number 

Figure 4.2 Peripheral Vector Number Format 


A31 


A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 DO 


ALL ZEROES 


V7 


V6 


V5 


V4 


V3 


V2 


VI 


VO 


Figure 4.3 Address Translated from 8-Bit Vector Number (TMP68000/TMP68008) 


31 



EXCEPTION VECTOR 
ADDRESS 


Figure 4.4 Exception Vector Address Calculation (TMP68010) | 

The actual address output on the address bus is truncated to the number of address 
bits available on the bus of the particular implementation of the TLCS-68000 
architecture. In the case of the TMP68000 and the TMP68010, this is 24 bits. In the 
case of the TMP68008, the address is 20 bits in length. 

The memory map for exception vectors is given in Table 4.2. 
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Table 4.2 Exception Vector Assignment 


Vector 

Number(s) 

Address 

Spaced 

Assignment 

Dec 

Hex 

0 

0 

000 

SP 

Reset: Initial SSP2 

1 

4 

004 

SP 

Reset: Initial PC2 

2 

8 

008 

SD 

Bus Error 

3 

12 

OOC 

SD 

Address Error 

4 

16 

010 

SD 

Illegal Instruction 

5 

20 

014 

SD 

Zero Divide 

6 

24 

018 

SD 

CHK Instruciton 

7 

28 

01C 

SD 

TRAPV Instruction 

8 

32 

020 

SD 

Privilege Violation 

9 

36 

024 

SD 

Trace 

10 

40 

028 

SD 

Line 1010 Emulator 

11 

44 

02C 

SD 

Line 1111 Emulator 

121 

48 

030 

SD 

(Unassigned, Reserved) 

131 

52 

034 

SD 

(Unassigned, Reserved) 

14 

56 

038 

SD 

Foramt Errors 

15 

60 

03C 

SD 

Uninitialized Interrupt Vector 

16-231 

64 

040 

SD 

(Unassigned, Reserved) 

92 

05C 


- 

24 

96 

060 

SD 

Spurious Interrupts 

25 

100 

064 

SD 

Level 1 Interrupt Autovector 

26 

104 

068 

SD 

Level 2 Interrupt Autovector 

27 

108 

06C 

SD 

Level 3 Interrupt Autovector 

28 

112 

070 

SD 

Level 4 Interrupt Autovector 

29 

116 

074 

SD 

Level 5 Interrupt Autovector 

30 

120 

078 

SD 

Level 6 Interrupt Autovector 

31 

124 

07C 

SD 

Level 7 Interrupt Autovector 

32-47 

128 

080 

SD 

TRAP Instruction Vectors4 

188 

OBC 


- 

48-631 

192 

OCO 

SD 

(Unassigned, Reserved) 

252 

OFC 


- 

64-255 

256 

100 

SD 

User Interrupt Vectors 

1020 

3FC 


- 


Notes: 

1. Vector numbers 12, 13, 16—23, and 48—63 are reserved for future enhancements. No user 
peripheral devices should be assigned these numbers. 
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2. Reset vector (0) requires four words, unlike the other vectors which only require two words, and 
is located in the supervisor program space. 

3. The spurious interrupt vector is taken when there is a bus error indication during interrupt 
processing. Refer to Paragraph “4.4.4 Spurious Interrupt”. 

4. TRAP #n uses vector number 32 + n. 

5. TMP68010 only. See Return from Exception Section. 

This vector is unassigned, reserved on the TMP68000 and TMP68008. 

6. SP denotes supervisor program space, and SD denotes supervisor data space. 

As shown in Table 4.2, the memory layout is 512 words long (1024 bytes). It starts at 
address 0 (decimal) and proceeds through address 1023 (decimal). This provides 255 
unique vectors; some of these are reserved for TRAPS and other system functions. Of 
the 255, there are 192 reserved for user interrupt vectors. However, there is no 
protection on the first 64 entries, so user interrupt vectors may overlap at the discretion 
of the systems designer. 

4.3.2 Kinds of Exceptions 

Exceptions can be generated by either internal or external causes. The externally 
generated exceptions are the interrupts, the bus error, and reset requests. The 
interrupts are requests from peripheral devices for processor action while the bus error 
and reset inputs are used for access control and processor restart. The internally 
generated exceptions come from instructions, or from address errors, or tracing. The 
trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK), and 
divide (DIV) instructions all can generate exceptions as part of their instruction 
execution. In addition, illegal instructions, word fetches from odd addresses, and 
privilege violations cause exceptions. Tracing behaves like a very high priority, 
internally generated interrupt after each instruction execution. 

4.3.3 Multiple Exceptions 

These paragraphs describe the processing which occurs when multiple exceptions 
arise simultaneously. Exceptions can be grouped accrding to their occurrence and 
priority. The group 0 exceptions are reset, bus error, and address error. These 
exceptions cause the instruction currently being executed to be aborted and the 
exception processing to commence within two clock cycles. The group 1 exceptions are 
trace and interrupt, as well as the privilege violations and illegal instructions. These 
exceptions allow the current instruction to execute to completion, but preempt the 
execution of the next instruction by forcing exception processing to occur (privilege 
violations and illegal instructions are detected when they are the next instruction to be 
executed). The group 2 exceptions occur as part of the normal processing of instructions. 
The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these 
exceptions, the normal execution of an instruction may lead to exception processing. 
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Group 0 exceptions have highest priority, while group 2 exceptions have lowest 
priority. Within group 0, reset has highest priority, followed by address error and then 
bus error. Within group 1, trace has priority over external interrupts, which in turn 
takes priority over illegal instruction and privilege violation. Since only one instruction 
can be executed at a time, there is no priority relation within group 2. 

The priority relation between two exceptions determines which is taken, or taken 
first, if the conditions for both arise simultaneously. Therefore, if a bus error occurs 
during a TRAP instruction, the bus error takes precedence, and the TRAP instriuction 
processing is aborted. In another example, if an interrupt request occurs during the 
execution of an instruction while the T bit is asserted, the trace exception has priority, 
and is processed first. Before instruction execution resumes, however, the interrupt 
exception is also processed and instruction processing commences finally in the 
interrupt handler routine. A summary of exception grouping and priority is given in 
Table 4.3. 


Table 4.3 Exception Grouping and Priority 


Group 

Exception 

Processing 


Reset 

Exception Processing 

0 

Address Error 

Begins Within Two 


Bus Error 

Clock Cycles 


Trace 

Exception Processing 

1 

Interrupt 

Begins Before The 

Illegal 

Privilege 

Next Instruction 


TRAP, TRAPV, 

Exception Processing is 

2 

CHK 

Started By Normal 


Zero Divide 

Instruction Execution 


4.3.4 Exception Stack Frames 

Exception processing saves the most volatile portion of the current processor context 
on the top of the supervisor stack. This context is organized in a format called the 
exception stack frame. Although this information varies with the particular processor 
and type of exception, it always includes the status register and program counter of the 
processor when the exception occurred. 

The amount and type of information saved on the stack is determined by the processor 
type and type of execution. Exceptions are grouped by type according to priority of the 
exception. The group 0 exceptions include address error, bus error, and reset. The group 
1 and 2 exceptions include interrupts, traps, illegal instructions, and trace. 

The TMP68000 and TMP68008 group 1 and 2 exception stack frame is shown in 
Figure 4.5. Only the program counter and status register are saved. The program 
counter points to the next instruction to be executed after exceptions processing. 
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The TMP68010 exception stack frame is shown in Figure 4.6. The number of 
words actually stacked depends on the exception type. Group 0 exceptions (except 
reset) stack 29 words and group 1 and 2 exceptions stack four words. In order to 
support generic exception handlers, the processor also places the vector offset in the 
exception stack frame. The format code field allows the RTF (return from exception) 
instruction to identify what information is on the stack so that it may be properly 
restored. Table 4.4 lists the TMP68010 stack format codes. Although some formats 
are peculiar to a particular TLCS-68000 Family processor, the format 0000 is always 
legal and indicates that just the first four words of the frame are present. 


EVEN BYTE . ODD BYTE 

7 0 I 7 0 

15 0 



STATUS REGISTER 

SSP- 

PROGRAM COUNTER HIGH 

PROGRAM COUNTER LOW 



HIGHER 

ADDRESS 


I 

I 


Figure 4.5 TMP68000/TMP68008 Group 1 and 2 Exception Stack Frame 

HIGHER 

ADDRESS 


15 _0 


STATUS REGISTER 


PROGRAM COUNTER HIGH 

PROGRAM COUNTER LOW 

FORMAT 

VECTOR OFFSET 


OTHER INFORMATION 

- DEPENDING ON EXCEPTION - 



Figure 4.6 TMP68010 Stack Frame 


Table 4.4 TMP68010 Format Codes 


Format Code 

Stacked Insformation 

0000 

Short Format (4 Words) 

1000 

Long Format (29 Words) 

All Others 

Unassigned, Reserved 
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4.3.5 Exception Processing Sequence 

Exception processing occurs in four identifiable steps. In the first step, an 
internal copy is made of the status register. After the copy is made, the S bit is 
asserted, putting the processor into the supervisor privilege state. Also, the T bit is 
negated, which will allow the exception handler to execute unhindered by tracing. 
For the reset and interrupt exceptions, the interrupt priority mask is also updated. 

In the second step, the vector number of the exception is determined. For 
interrupts, the vector number is obtained by a processor fetch and classified as an 
interrupt acknowledge. For all other exceptions, internal logic provides the vector 
number. This vector number is then used to generate the address of the exception 
vector. Group 1 and 2 exceptions use a short format exception stack frame (format = 
0000 on the TMP68010). Additional information defining the current context is 
stacked for the bus error and address error exceptions. 

The third step is to save the current processor status, except for the reset 
exception. The current program counter value and the saved copy of the status 
register are stacked using the supervisor stack pointer. The program counter value 
stacked usually points to the next unexecuted instruction, however for bus error and 
address error, the value stacked for the program counter is unpredictable and may 
be incremented from the address of the instruction which caused the error. 
Additional information defining the current context is stacked for the bus error and 
address error exceptions. 

The last step is the same for all exceptions. The new program counter value is 
fetched from the exception vector. The processor then resumes instruction 
execution. The instruction at the address given in the exception vector is fetched 
and normal instruction decoding and execution is started. 

4.4 EXCEPTION PROCESSING DETAILED DISCUSSION 

Exceptions have a number of sources and each exception has processing which is 
peculiar to it. The following paragraphs detail the source of exceptions, how each 
arises, and how each is processed. 
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4.4.1 Reset 

The reset input provides the highest exception level. The processing of the reset 
signal is designed for system initiation and recovery from catastrophic failure. Any 
processing in progress at the time of the reset is aborted and cannot be recovered. 
The processor is forced into the supervisor state and the trace state is forced off. The 
processor interrupt priority mask is set at level seven. In the TMP6801, the vector 
base register (VBR) is forced to zero. The vector number is internally generated to 
reference the reset exception vector at location 0 in the supervisor program space. 
Because no assumptions can be made about the validity of register contents, in 
particular the supervisor stack pointer, neither the program counter nor the status 
register is saved. The address contained in the first two words of the reset exception 
vector is fetched as the initial supervisor stack pointer and the address in the last 
two words of the reset exception vector is fetched as the initial program counter. 
Finally, instruction execution is started at the address in the program counter. The 
power-up/restart code should be pointed to by the initial program counter. 

The RESET instruction does not cause loading of the reset vector, but does assert 
the reset line to rest external devices. This allows the software to reset the system to 
a known state and then continue processing with the next instruction. 

4.4.2 Interrupts 

Seven levels of interrupt priorities are provided. In the TMP68000, and 
TMP68010 all seven levels are available. The TMP68008 supports three interrupt I 
levels: two, five, and seven, level seven being the highest priority. Devices may be | 
chained externally within interrupt priority levels, allowing an unlimited number of 
peripheral devices to interrupt the processor. Interrupt priority levels are numbered 
from one to seven, level seven being the highest priority. The status register 
contains a three-bit mask which indicates the current processor priority and 
interrupts are inhibited for all priority levels less than or equal to the current 
processor priority. 

An interrupt request is made to the processor by encoding the interrupt request 
level on the interrupt request lines; a zero indicates no interrupt request. Interrupt 
requests arriving at the processor do not force immediate exception processing, but 
are made pending. Pending interrupts are detected between instruction executions. 

If the priority of the pending interrupt is lower than or equal to the current processor 
priority, execution continues with the next instruction and the interrupt exception 
processing is postponed. 


VMPU-51 



TOSHIBA 


TLCS-68000 


If the priority of the pending interrupt is greater than the current processor 
priority, the exception processing sequence is started. A copy of the status register is 
saved, the privilege state is set to supervisor state, tracing is suppressed, and the 
processor priority level is set to the level of the interrupt being acknowledged. The 
processor fetches the vector number from the interrupting device, classifying the 
reference as an interrupt acknowledge and displaying the level number of the 
interrupt being acknowledged on the address bus. If external logic requests 
automatic vectoring, the processor internally generates a vector number which is 
determined by the interrupt level number. If external logic indicates a bus error, the 
interrupt is taken to be spurious, and the generated vector number references the 
spurious interrupt vector. The processor then proceeds with the usual exception 
processing, saving the format/offset word (TMP68010 only), program counter, and 
status register on the supervisor stack. The offset value in the format/offset word on 
the TMP68010 is the externally supplied or internally generated vector number 
multiplied by four. The format will be all zeroes. The saved value of the program 
counter is the address of the instruction which would have been executed had the 
interrupt not been present. The content of the interrupt vector whose vector number 
was previously obtained is fetched and loaded into the program counter, and normal 
instruction execution commences in the interrupt handling routine. 

Priority level seven is a special case. Level seven interrupts cannot be inhibited 
by the interrupt priority mask, thus providing a “non-maskable interrupt” 
capability. An interrupt is generated each time the interrupt request level changes 
from some lower level to level seven. Note that a level seven interrupt may still be 
caused by the level comparison if the request level is a seven and the processor 
priority is set to a lower level by an instruction. 

4.4.3 Uninitialized Interrupt 

An interrupting device asserts VPA, BERR, or provides 
and TLCS-68000 interrupt vector number and asserts DTACK during 
an interrupt acknowledge cycle by the TLCS-68000. If the vector register has not 
been initialized, the responding TLCS-68000 Family peripheral will provide vector 
number 15, the uninitialized interrupt vector. This provides a uniform way to 
recover from a programming error. 

4.4.4 Spurious Interrupt 

If during the interrupt acknowledge cycle no device responds by asserting 
DTACK or VPA, BERR should be asserted to 

terminate the vector acquisition. The processor separates the processing of this 
error from bus error by forming a short format exception stack and fetching the 
spurious interrupt vector instead of the bus error vector. The processor then 
proceeds with the usual exception processing. 
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4.4.5 Instruction Traps 

Traps are exceptions caused by instructions. They arise either from processor 
recognition of abnormal conditions during instruction, execution, or from use of 
instructions whose normal behavior is trapping. 

Exception processing for traps is straightforward. The status register is copied, 
the supervisor state is entered, and the trace state is turned off. The vector number 
is internally generated; for the TRAP instruction, part of the vector number comes 
from the instruction itself. The program counter and the copy of the status register 
are saved on the supervisor stack. The saved value of the program counter is the 
address of the instruction after the instruction which generated the trap. Finally, 
instruction execution commences at the address contained in the exception vector. 

Some instructions are used specifically to generate traps. The TRAP instruction 
always forces an exception and is useful for implementing system calls for user 
programs. The TRAPV and CHK instructions force an exception if the user program 
detects a runtime error, which may be an arithmetic overflow or a subscript out of 
bounds. 

The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an 
exception if a division operation is attempted with a divisor of zero. 

4.4.6 Illegal and Unimplemented Instructions 

Illegal instruction is the term used to refer to any of the word bit patterns which 
are not the bit patterns of the first word of a legal TLCS-68000 instruction. During 
instruction execution, if such an instruction is fetched, an illegal instruction 
exception occurs. Three bit patterns will always force an illegal instruction trap on 
all TLCS-68000 Family compatible microprocessors. They are: $4AFA, $4AFB, and 
$4AFC. Two of the patterns, $4AFA and $4AFB, are reserved for the system 
products. The third pattern, $4AFC, is reserved for customer use. 

In addition to the previously defined illegal instruction opcodes, the TMP68010 
defines eight breakpoint illegal instructions with the bit patterns $4848~$484F. 
These instructions cause the processor to enter illegal instruction exception 
processing as usual, but a breakpoint bus cycle is executed before the stacking 
operations are performed in which the function code lines (FC0'^FC2)are high and 
address lines are all low. The processor does not accept or send any data during this 
cycle. Whether the breakpoint cycle is terminated with a DTACK, 

BERR, or VPA signal, the processor will continue with the 
illegal instruction processing. The purpose of this cycle is to provide a software 
breakpoint that will signal external hardware when it is executed. See TMP68010 
Advanced Information data sheet. 
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Word patterns with bits 15"^ 12 equaling 1010 or 1111 are distinguished as 
unimplemented instructions and separate exception vectors are given to these 
patterns to permit efficient emulation. This facility allows the operating system to 
detect program errors or to emulate unimplemented instructions in software. 

Exception processing for illegal instructions is similar to that for traps. After the 
instruction is fetched and decoding is attempted, the processor determines that 
execution of an illegal instruction is being attempted and starts exception 
processing. The exception stack frame for group 2 is then pushed on the supervisor 
stack and the illegal instruction vector is fetched. 

4.4.7 Privilege Violations 


In order to provide system security, various instructions are privileged. An 
attempt to execute one of the privileged instructions while in the user state will 
cause an exception. The privileged instructions are: 


AND Immediate to SR 
EOR Immediate to SR 
MOVE to SR 
MOVE from SR* 
MOVEC* 

MOVES* 

*: TMP68010 


MOVE USP 

OR Immediate to SR 

RESET 

RTE 

STOP 


Exception processing for privilege violations is nearly identical to that for illegal 
instructions. After the instruction is fetched and decoded, and the processor 
determines that a privilege violation is being attempted, the processor starts 
exception processing. The status register is copied, the supervisor state is entered, 
and the trace state is turned off. The vector number is generated to reference the 
privilege violation vector, and the current program counter and the copy of the 
status register are saved on the supervisor stack and, if the processor is an 
TMP68010, the format/offset word, is also saved. The saved value of the program 
counter is the address of the first word of the instruction which caused the privilege 
violation. Finally, instruction execution commences at the address contained in the 
privilege violation exception vector. 

4.4.8 Tracing 

To aid in program development, the TLCS-68000 includes a facility to allow 
instruction by instruction tracing. In the trace state, after each instruction is 
executed, an exception is forced, allowing a debugging program to monitor the 
execution of the program under test. 
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The trace facility uses the T bit in the supervisor portion of the status register. If 
the T bit is negated (off), tracing is disable and instruction execution proceeds from 
instruction to instruction as normal. If the T bit is asserted (on) at the beginning of 
the execution of an instruction, a trace exception will be generated after the 
execution of that instruction is completed. If the instruction is not executed, either 
because an interrupt is taken or the instruction is illegal or privileged, the trace 
exception does not occur. The trace exception also does not occur if the instruction is 
aborted by a reset, bus error, or address error exception. If the instruction is indeed 
executed and an interrupt is pending on completion, the trace exception is processed 
before the interrupt exception, if, during the execution of the instruction, an 
exception is forced by that instruction, the forced exception is processed before the 
trace exception. As an extreme illustration of the above rules, consider the arrival of 
an interrupt during the exception of a TRAP instruction while tracing is enabled. 
First the trap exception is processed, then the trace exception, and finally the 
interrupt exception. Instruction execution resumes in the interrupt handler routine. 

The exception processing for trace is quite simple. After the execution of the 
instruction is completed and before the start of the next instruction, exception 
processing begins. A copy is made of the status register. The transition to 
supervisor privilege state is made and, as usual, the T bit of the status register is 
turned off, disabling further tracing. The vector number is generated to reference 
the trace exception vector, and the current program counter, the copy of the status 
register and, on the TMP68010, the format/offset word are saved on the supervisor 
stack. The saved value of the program counter is the address of the next instruction. 
Instruction execution commences at the address contained in thetrace exception 
vector. 

4.4.9 Bus Error 

Bus error exceptions occur when the external logic requests that a bus error be 
processed by an exception. The current bus cycle which the processor is making is 
then aborted. Whether the processor was doing instruction or exception processing, 
that processing is terminated and the processor immediately begins exception 
processing. 

The bus error facility is identical on the TMP68000 and TMP68008; however, the 
stack frame produced on the TMP68010 contains more information. This is to allow 
the instruction continuation facility which can be used to implement virtual 
memory on the TMP68010 processor. Bus error for the TMP68000/TMP68008 and 
for the TMP68010 are described separately below. 
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4.4.9.1 Bus Error (TMP68000/TMP68008) 

Exception processing for bus error follows the usual sequence of steps. The status 
register is copied, the supervisor state is entered, and the trace state is turned off. The 
vector number is generated to refer to the bus error vector. Since the processor was not 
between instructions when the bus error exception request was made, the context of the 
processor is more detailed. To save more of this context, additional information is saved 
on the supervisor stack. The program counter and the copy of the status register are of 
course saved. The value saved for the program counter is advanced by some amount, two 
to ten bytes beyond the address of the first word of the instruction which made the 
reference causing the bus error. If the bus error occurred during the fetch of the next 
instruction, the saved program counter has a value in the vicinity of the current 
instruction, even if the current instruction is a branch, a jump, or a return instruction. 
Besides the usual information, the processor saves its internal copy of the first word of 
the instruction being processed and the address which was being accessed by the aborted 
bus cycle. Specific information about the access is also saved: whether it was a read or 
write, whether the processor was processing an instruction or not, and the classification 
displayed on the function code outputs when the bus error occurred. The processor is 
processing an instruction if it is in the normal state or processing a group 2 exception; 
the processor is not processing an instruction if it is processing a group 0 or a group 1 
exception. Figure 4.7 illustrates how this information is organized on the supervisor 
stack. If a bus error occurs during the last step of exception processing, while either 
reading the exception vector or fetching the instruction, the value of the program 
counter is the address of the exception vector. Although this information is not 
sufficient in general to effect full recovery from the bus error, it does allow software 
diagnosis. Finally, the processor commences instruction processing at the address 
contained in the vector. It is the responsibility of the error handler routine to clean up 
the stack and determine where to continue execution. 

If a bus error occurs during the exception processing for a bus error, address error, or 
read, the processor is halted, and all processing ceases. This simplifies the detection of a 
catastrophic system failure, since the processor removes itself from the system rather 
than destroy all memory contents. Only the RESET pin can restart a halted processor. 
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15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

LOWER 
ADDRESS 


Figure 4.7 Supervisor Stack Order for Bus or Address Error Exception 
4.4.9.2 BUS ERROR (TMP68010) 

Exception processing for a bus error follows a slightly different sequence than the 
sequence for group 1 and 2 exceptions. In addition to the four steps executed during 
exception processing for all other exceptions, 22 words of additional information are 
placed on the stack. This additional information describes the internal state of the 
processor at the time of the bus error and is reloaded by the RTE instruction to 
continue the instruction that caused the error. Figure 4.8 shows the order of the 
stacked information. 







R/W 

l/N 

FUNCTION CODE 


ACCESS ADDRESS 


HIGH 

LOW 


INSTRUCTION REGISTER 


STATUS REGISTER 


PROGRAM COUNTER 


HIGH 

LOW 


R/W {Read/Write): Write = 0, Read = 1 
l/N (Instruction/Not): Instruction = 0, Not= 1 
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15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


STATUS REGISTER 

PROGRAM COUNTER (HIGH) 

PROGRAM COUNTER (LOW) 

1000 VECTOR OFFSET 

SPECIAL STATUS WORD 

FAULT ADDRESS (HIGH) 

FAULT ADDRESS (LOW) 

UNUSED, RESERVED 

DATA OUTPUT BUFFER 

UNUSED, RESERVED 

DATA INPUT BUFFER 

UNUSED, RESERVED 

INSTRUCTION INPUT BUFFER 

INTERNAL INFORMATION, 16 WORDS 


Note: The stack pointer is decremented by 29 words, although only 26 words of information are 
actually written to memory. The three additional words are reserved for future use. 

Figure 4.8 Exception Stack Order (Bus and Address Error) 


The value of the saved program counter does not necessarily point to the 
instruction that was executing when the bus error occurred, but may be advanced by 
up to five words. This is due to the prefetch mechanism on the TMP68010 that 
always fetches a new instruction word as each previously fetched instruction word is 
used. However, enough information is placed on the stack for the bus error 
exception handler routine to determine why the bus fault occurred. This additional 
information includes the address that was being accessed, the function codes for the 
access, whether it was a read or a write, and what internal register was included in 
the transfer. The fault address can be used by an operating system to determine 
what virtual memory location is needed so that the requested data can be brought 
into phyical memory. The RTE instruction is then used to reload the processor’s 
internal state at the time of the fault, the faulted bus cycle will then be re-run and 
the suspended instruction completed. If the faulted bus cycle was a read-modify- 
write, the entire cycle will be re-run whether the fault occurred during the read or 
the write operation. 
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An alternate method of handling a bus error is to complete the faulted access in 
software. In order to use this method, use of the special word, the instruction input 
buffer, the data input buffer, and the data output buffer image is required. The 
format of the special status word is shown in Figure 4.9. If the bus cycle was a write, 
the data at the fault address location should be written to the images of the data 
input buffer, instruction input buffer, or both accoding to the DF and IF bits*. In 
addition, for read-modify-write cycles, the status register image must be properly set 
to reflect the read data if the fault occurred during the read portion of the cycle and 
the write operation (i.e., setting the most significant bit of the memory location) 
must also be performed. This is because the entire read-modify-write cycle is 
assumed to have been completed by software. Once the cycle has been completed by 
software, the RR bit in the special status word is set to indicate to the processor that 
is should not re-run the cycle when the RTE instruction is executed. If the re-run 
flag is set when an RTE instruction executes, the TMP68010 still reads all of the 
information from the stack. 

* : If the faulted access was a byte operation, the data should be moved from or to 
the least-significant byte of the data output or input buffer images unless the 
HB bit is set. This condition will only occur if a MOVEP instruction caused the 
fault during transfer of bits 8~15 a word or long word or bits 24~31 of a long 
word. 


15 

14 

13 

12 

11 

10 

9 

8 

7-3 

2 1 0 

RR 

* 

IF 

DF 

RM 

HB 

BY 

RW 

* 

FC2~FC0 


RR - 
IF - 
DF - 
RM - 
HB - 
BY - 

RW - 
FC - 


Re-run flag; 0 = processor re-run (default), 1 = softrware re - run. 

Instruction fetch to the Instruction Input Buffer. 

Data fetch to the Data Input Buffer. 

Read-Modify-Write cycle. 

High byte transfer from the Data Output Buffer or to the Data input Buffer. 
Byte transfer flag; HB selects the high or low byte of the transfer register. 

If BY is clear, the transfer is word. 

ReadAA/rite flag; 0 = write, 1 = read. 

The function code used during the faulted access. 

These bits are reserved for future use and will be zero when written by the 
TMP68010. 


Figure 4.9 Special Status Word Format 
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4.4.10 Address Error 

Address error exceptions occur when the processor attempts to access a word or a 
long word operand or an instruction at an odd address. The effect is much like an 
internally generated bus error, so that the bus cycle is aborted, and the processor 
ceases whatever processing it is currently doing and begins exception processing. 
After exception processing commences, the sequence is the same as that for bus error 
including the information that is stacked, except that the vector number refers to 
the address error vector instead. Likewise, if an address error occurs during the 
exception processing for a bus error, address error, or reset, the processor is halted. 

On the TMP68010, the address error exception stacks the same information that 
is stacked by a bus error exception, therefore it is possible to use the RTE instruction 
to continue execution of the suspended instruction. However, if the software re-run 
flag is not set, the fault address will be used when the cycle is re-run and another 
address error exception will occur. Therefore, the user must be certain that the 
proper corrections have been made to the stack image and user registers before 
attempting to continue the instruction. With proper software handling, the address 
error exception handler could emulate word or long word accesses to odd addresses 
ifdesired. 

4.5 RETURN FROM EXCEPTION (TMP68Q10) 

In addition to returning from any exception handler routine on the TMP68010, 
the RTE instruction is used to resume the excution of a suspended instruction by 
restoring all of the temporary register and control information stored during a bus 
error and returning to the normal processing state. For the RTE instruction to 
execute properly, the stack must contain valid and accessible data. The RTE 
instruction checks for data validity in two ways; first, by checking the format/offset 
word for a valid stack format code, and second, if the format code indicates the long 
stack format, the long stack data is checked for validity as it is loaded into the 
processor. In addition, the data is checked for accessibility when the processor starts 
reading the long data. Because of these checks, the RTE instruction executes as 
follows: 

4.5.1 Determine The Stack Format 

This step is the same for any stack format and consists of reading the status 
register, program counter, and format/offset word. If the format code indicates a 
short stack format, execution continues at the new program counter address. If the 
format code is not one of the TMP68010 defined stack format codes, exception 
processing starts for a format error. 
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4.5.2 Determine Data Validity 

For a long stack format, the TMP68010 will begin to read the remaining stack 
data, checking for validity of the data. The only word checked for validity is the first 
of the 16 internal information words (SP + 26) shown in Figure 4.8. This word 
contains a processor version number (in bits 10~13) in addition to proprietary 
internal information that must match the version number of the TMP68010 that is 
attempting to read the data. This validity check is used to insure that in 
multiprocessor systems, the data will be properly interpreted by the RTE instruction 
if the two processors are of different versions. If the version number is incorrect for 
this processor, the RTE instruction will be aborted and exception processing will 
begin for a format error exception. Since the stack pointer is not updated until the 
RTE instruction has successfully read all of the stack data, a format error occurring 
at this point will not stack new data over the previous bus error stack information. 

4.5.3 Determine Data Accessibility 

If the long stack data is valid, the TMP68010 performs a read from the last word 
(SP + 56) of the long stack to determine data accessibility. If this read is terminated 
normally, the processor assumes that the remaining words on the stack frame are 
also accessible. If a bus error is signaled before or during this read, a bus error 
exception is taken as usual. After this read, the processor must be able to load the 
remaining data without receiving a bus error; therefore, if a bus error occurs on any 
of the remaining stack reads, the TMP68010 treats this as a double bus fault and 
enters the halted state. 
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APPENDIX A CONDITION CODES COMPUTATION 

A.l INTRODUCTION 

This appendix provides a discussion of how the condition codes were developed, the 
meanings of each bit, how they are computed, and how they are represented in the 
instruction set details. 

Two criteria were used in developing the condition codes: 

• Consistency — across instruction, uses, and instances 

• Meaningful Results — no change unless it provides useful information 

The consistency across instructions means that instructions which are special cases of 
more general instructions affect the condition codes in the same way. Consistency 
across instances means that if an instruction ever affects a condition code, it wil] always 
affect that condition code. Consistency across uses means that whether the condition 
codes were set by a compare, test, or move instruction, the conditional instructions test 
the same situation. The tests used for the conditional instructions and the code 
computations are given in paragraph A.5. 

A.2 CONDITION CODE REGISTER 

The condition code register portion of the status register contains five bits: 

N — Negative 
Z — Zero 
V — Overflow 
C — Carry 
X — Extend 

The first four bits are true condition code bits in that they reflect the condition of the 
result of a processor operation. The X bit is an operand for multiprecision computations. 
The carry bit (C) and the multiprecision operand extend bit (X) are separate in the 
TLCS —68000 Family to simplify the programming model. 

A.3 CONDITION CODE REGISTER NOTATION 

In the instruction set details given in “APPENDIX B”, the description of the effect on 
the condition codes is given in the following form: 
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X N Z V C 
Condition Codes: I I \ 


where: 

N (negative) Set if the most significant bit of the result is set. Cleared 
otherwise. 


Z (zero) 

V (overflow) 


C (carry) 


Set if the result equals zero. Cleared otherwise. 

Set if there was an arithmetic overflow. This implies that the 
result is not representable in the operand size. Cleared otherwise. 

Set if a carry is generated out of the most significant bit of the 
operands for an addition. Also, set if a borrow is generated in a 
subtraction. Cleared otherwise. 


X (extend) Transparent to data movement. When affected, by arithmetic 
operations, it is set the same as the C bit. 


The convention for the notation that is used in the condition code register 
representation is: 

* : set according to the result of the operation 
- : not affected by the operation 

0 : cleared 

1 : set 

U : undefined after the operation 

A.4 CONDITION CODE COMPUTATION 


Most operations take a source operand and a destination operand, compute, and store 
the result in the destination location. Unary operations take a destination operand, 
compute, and store the result in the destination location. Table A.l details how each 
instruction sets the condition codes. 
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Table A.l Condition Code Computations 


Operations 

X 

N 

z 


C 

Special Definition 

ABCD 

* 

U 

■ 

H 

7 

C = Decimal Carry 

Z = Z ARm A —A'RD 

ADD, ADD!, 

ADDQ 

* 

* 

■ 

■ 

7 

V = Sm A Dm A Rm v ^ A Dm A Rm 

C = Sm A Dm V ^ A Dm v Sm A Rm 

ADDX 

* 

* 

■ 

■ 

7 

V = Sm A Dm A Rrn v Sm A C5rn A Rm 

C = Sm A Dm v A Dm v Sm A Rm 

Z = Z ARrii A-ARO 

AND, ANDI, EOR, EORI, 

MOVE, MOVEQ, OR, ORI, 

CLR, NXT, NOT, TAS, TST 


* 

* 


0 


CHK 

— 

* 

■9 

wm 

U 


SUB, SUBI, 

SUBQ 

* 

* 

* 

7 

7 

V = ^ A Dm A Rrn v Sm A Dm A Rm 

C = Sm AUm V Rm A Dm" v Sm A Rm 

SUBX 

•k 

* 

7 

7 

7 

V = Srn A Dm A Rm vSm A Drn A Rm 

C = Sm A Dm v Rm A Drn v Sm A Rm 

Z = ZARm A-ARD 

CMP, 

CMPI, CMPM 


* 

* 

■ 

? 

V = Sm A Dm A Rrn v Sm AUm A Rm 

C = Sm ADrn V Rm A DFnv Sm A Rm 

DIVS, DIVU 

— 

* 

* 


O 

V = Division Overflow 

MULS, MULU 

— 

* 

* 

■1^ 

O 


SBCD, NBCD 

* 

u 

7 

u 

7 

C = Decimal Borrow 

Z = Z ARm A-ARC 

NEC 

* 

* 

* 

7 

7 

V = Dm A Rm, C = Dm v Rm 

NEGX 

* 

* 

7 

7 

7 

V = Dm A Rm, C = Dm v Rm 

Z = ZARm A-ARO 

BIST, BCHG, BSET, BCLR 

— 

— 

7 

— 

— 

Z = Dm 

ASL 

* 

* 

* 

7 

7 

V = Dm A (Dm-1 v V Dm-r) 

+ Drn A (Dm-1 v *” V Dm-r) 

C = Dm-r +1 

ASL(r = 0) 

— 

* 

* 

WBM 



LSI, ROXL 

* 

■k 

* 

■a 

_L_ 

C = Dm-r + 1 

LSR (r = 0) 

— 

* 

* 

o 

El 



1^9! 

■■ 

MM 

0 

7 

C = X 

ROL 

— 

* 

* 

0 

7 

C = Dm-r + 1 

ROL(r = 0) 

— 

■1 

* 

0 

0 


ASR, LSR, ROXR 

* 

* 

* 

0 

7 

C = Dr-1 


iB 


mi 

■9 

MM 


ROXR (r = 0) 

— 

* 

■k 

wm 


C = X 

ROR 

— 

* 

* 

0 


C = Dr-1 

ROR (r = 0) 

- 

* 

* 

■a 

lEI 



- = 

Not Affected 

Rm 

= 

Result Operand —most significant bit 

U = 

Undefined, result meaningless 

R 

= 

Register Tested 

7 = 

Other — See Special Definition 

n 

= 

Bit Number 

* _ 

General Case 

r 

= 

Shift Count 

X = 

C 

LB 

= 

Lower Bound 

N = 

Rm 

UB 

= 

Upper Bound 

Z = 

RmA'”ARO 

A 


Boolean AND 

Sm = 

Source Operand — most significant bit 

V 

= 

Boolean OR 

Dm 

= Destination Operand — most significant bit 

Rm 

zz 

NOT Rm 
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A.5 CONDITION TESTS 

Table A.2 lists the condition names, encodings, and tests for the condition branch and 
set instructions. 

The test associated with each condition is a logical formula based on the current state 
of the condition codes. If this formula evaluates to one, the condition succeeds, or is true. 
If the formula evaluates to zero, the condition is unsuccessful, or false. For example, the 
T condition always succeeds, while the EQ condition succeeds only if the Z bit is 
currently set in the condition codes. 


Table A.2 Conditional Tests 


Mnemonic 

Condition 

Encoding 

Test 

T* 

True 

0000 

1 

F* 

False 

0001 

0 

HI 

High 

0010 

C- Z 

LS 

Low or Same 

0011 

C+ Z 

CC{HS) 

Carry Clear 

0100 

C 

CS (LO) 

Carry Set 

0101 

C 

NE 

Not Equal 

0110 

Z 

EQ 

Equal 

0111 

Z 

VC 

Overflow Clear 

1000 

V 

VS 

Overflow Set 

1001 

V 

PL 

Plus 

1010 

N 

Ml 

Minus 

1011 

N 

GE 

Greater or Equal 

1100 

N • V + N • V 

LT 

Less Than 

1101 

N-V + N* V 

GT 

Greater Than 

1110 

N-V-Z + N-V-Z 

LE 

Less or Equal 

1111 

Z + N* V + N • V 


• = Bloolean AND 

+ = Bloolean OR 

N = Bloolean NOT N 

* : Not available for the Bcc instruction 
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APPENDIX B INSTRUCTION SET DETAILS 

B.l INTRODUCTION 

This appendix contains detailed information about each instruction in the 
TLCS —68000 instruction set. They are arranged in alphabetical order with the 
mnemonic heading set in large bold type for easy reference. 

B.2 ADDRESSING CATEGORIES 

Effective address modes may be categorized by the ways in which they may be used. 
The following classifications will be used in the instruction definitions. 

Data : If an effective address mode may be used to refer to data operands, it is 
considered a data addressing effective address mode. 

Memory : If an effective address mode may be used to refer to memory operands, it 
is considered a memory addressing effective address mode. 

Alterable : If an effective address mode may be used to refer to alterable (writeable) 
operands, it is considered an alterable addressing effective address 
mode. 

Control : If an effective address mode may be used to refer to memory operands 

without an associated size, it is considered a control addressing effective 
address mode. 

Table B.l shows the various categories to which each of the effective address modes 
belong. 
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Table B.l Effective Addressing Mode Categories 


Address Modes 

Mode 

Register 

Data 

Memory 

Control 

Alterable 

Assembler 

Syntax 

Data Register Direct. 

000 

reg. no. 

X 

- 

- 

X 

Dn 

Address Register Direct 

001 

reg no 

- 

- 

- 

X 

An 

Address Register Indirect 
Address Register Indirect 

010 

reg. no. 

X 

X 

X 

X 

(An) 

with Postincrement 
Address Register Indirect 

oil 

reg. no. 

X 

X 


X 

(An) + 

with Predecrement 
Address Register Indirect 

100 

reg. no. 

X 

X 


X 

-(An) 

with Displacement 

101 

reg. no. 

X 

X 

X 

X 

d16(An) 

Address Register Indirect 
with Index 

110 

reg. no. 

X 

X 

X 

X 

d8(An,Xn) 

Absolute Short 

111 

000 

X 

X 

X 

X 

Abs.W 

Absolute long 

111 

001 

X 

X 

X 

X 

Abs. L 

Program Counter Indirect 
with Displacement 

111 

101 

X 

X 

X 

— 

die (PC) 

Program Counter Indirect 
with Index 

111 

oil 

X 

X 

X 

- 

d8 (PC, Xn) 

Immediate 

111 

100 

X 

X 

- 

- 

#<data > 


These categories may be combined so that additional, more restrictive, classifications 
may be defined. For example, the instruction descriptions use such classifications as 
alterable memory or data alterable. The former refers to those addressing modes which 
are both alterable and memory addresses, and the latter refers to addressing modes 
which are both data and alterable. 
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B.3 INSTRUCTION DESCRIPTION 

The formats of each instruction are given in the following pages. Figure B.l 
illustrates what information is given. 

Instruction Name - ABCD Add Decimal 

Operation : Sourceio+ Destinaitonio. 


Assembler ABCD Dy, Dx 

Syntax : ABCD — (Ay), — (Ax) 

Attributes : Size (Byte) 

Text Description of Instruction Operation —Description : Add the source operand 

Condition Code Effects -►Condition Codes : 

(see "Appendix A") 


X N Z V C 



N Undefined. 

Z Cleared if the result is non-zero. 

Instruction Format - Specifies the 
bit pattern and fields of the 
operation word and any other 
words which are part of the 
instruction. The effective address 
extensions are not explicitly 
illustrated. The extensions (if there 
are any) would follow the 
illustrated portions of the 
instructions. For the MOVE 
instruction, the source effective 
address extension is the first, 
foil owed by the destination 
effective address extension. 

Meanings and allowed values of -^ Instructuion Fields : 

the various fields required by the 
instruction format. 

Figure B. 1 Instruction Description Format 



Operation Description - 

(see "B.4 OPERATION DESCRIPTION 
DEFINITIONS") 

Assembler Syntax for this Instruction 
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B.4 OPERATION DESCRIPTION DEFINITIONS 

The following definitions are used for the operation description in the details of the 
instruction set. 

OPERAND: 


An 

Dn 

Xn 

PC 

SR 

OCR 

SSP 

USP 

SP 

X 

N 

z 

V 

c 

Immediate Data 

d8 

dl6 

disp 

Source 

Destination 

Vector 

ea 


— address register 

— data register 

— any data or address register 

— program counter 

— status register 

— condition codes (lower order byte of status register) 

— supervisor stack pointer 

— user stack pointer 

— active stack pointer (equivalent to A7) 

— extend operand (from condition codes) 

— negative condition code 

— zero condition code 

— overflow condition code 

— carry condition code 

— immediate data from the instruction 

— 8-bit address displacement 

— 16-bit address displacement 

— address displacement (d8 or dl6) 

— source contents 

— destination contents 

— location of exception vector 

— any valid effective address 


SUBFIELDS AND QUALIFIERS: 


<bit> of < operand > 

(< operand >) 

< operand > lo 

(< address register >) 

“ (< address register >) 
(< address register >) + 
# <data> 


selects a single bit of the operand 
the contents of the referenced location 
the operand is binary coded decimal; operations are to be 
performed in decimal. 

the register indirect operator which indicates that the 
operand register points to the memory locatiaon of the 
instructuon operand. 

immediate data located with the instruction is the operand. 
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OPERATIONS: Operations are grouped into binary, unary, and other. 

Binary — These operations are written < operand > < op > < operand > where < op > 
is one of the following: 

: the left operand is moved to the right operand 

: the two operands are exchanged 

-f- : the operands are added 

— : the right operand is subtracted from the left operand 

* : the operands are multiplied 

/ : the first operand is divided by the second operand 

A : the operands are logically ANDed 

V : the operands are logically ORed 

© : the operands are logically exclusively ORed 

< : relational test, true if left operand is less than right 

operand 

> : relational test, true if left operand is greater than right 

operand 

shifted by the left operand is sfifted or rotated by the number of 

positions 

rotated by specified by the right operand 

Unary: 

~ < operand > the operand is logically complemented 

< operand > sign-extended the operand is sign extended, all bits of the upper portion 

are made equal to high order bit of the lower portion 

< operand > tested the operand is compared to 0, the results are used to set the 

condition codes 


Other : 

TRAP equivalent to SSP — 2 SSP; Format/Offset Word-> (SSP); SSP — 4-^SSP; 

PC-^(SSP); SSP~2-»SSP; SR->(SSP); (vector)->PC 

STOP enter the stopped state, waiting for interrupts 

If < condition > then < operation > else < operation >. The condition is tested. If true, 
the operations after the “then” are performed. If the condition is false and the 
optional “else” clause is present, the operations after the “else” are performed. If the 
condition is false and the optional “else” clause is absent, the instruction performs no 
operation. 

; Semicolon is used to separate operations and terminatethe if/then/else operation. 
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ABCD 


Add Decimal With Extend ABCD 


Operation 


Sourceio + Destinationio + XDestination 


Assembler 

Syntax 


ABCD Dx, Dy 
ABCD -(Ax),-(Ay) 


Attributes 


Size = (Byte) 


Description 


Add the source operand to the destination operand along with the extend bit, 
and store the result in the destination location. The addition is performed 
using binary coded decimal arithmetic. The operands may be addressed in 
two different ways: 

1. Data register to data register: The operands are contained in the data 
registers specified in the instruction. 

2. Memory to memory: The operands are addressed with the predecrement 
addressing mode using the address registers specified in the instruction. 

This operation is a byte operation only. 


Condition Codes : 


X 

N 

Z 

V 

c 

E] 

U 

EJ 

E 

EJ 


N : Undefined. 

Z : Cleared if the result is non-zero. Unchanged otherwise. 

V : Undefined. 

C : Set if a carry (decimal) was generated. Cleared otherwise. 

X : Set the same as the carry bit. 

Note: 

Normally the Z condition code bit is set via programming before the start of 
an operation. This allows successful tests for zero results upon completion of 
multiple-precision operations. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 

□ 

1 

0 

0 

Register 

Xv 

□ 

0 

0 

0 

0 

R/M 

Register 

Xx 
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ABCD 


ABCD 


Instruction Fields: 

Register Xy field — Specifies the destination register: 

If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode 

R/M field — Specifies the operand addressing mode: 

0 — The operation is data register to data register 
1 — The operation is memory to memory 

Register Xx field — Specifies the source register: 

If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode 
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ADD 


Add Binary 


ADD 


Operation 


Source + Destination —^ Destination 


Assembler 

Syntax 


ADD <ea>,Dn 
ADD Dn, <ea> 


Attributes : Size = (Byte, Word, Long word) 

Description : Add the source operand to the destination operand using binary addition, and 
store the result in the destination location. The size of the operation may be 
specified to be byte, word, or long word. The mode of the instruction indicates 
which operand is the source and which is the destination as well as the 
operand size. 


Condition Codes 



N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a carry is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

The condition codes are not affected when the destination is an address register. 
Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

□ 

1 

0 

1 1 

Register 

Dn 

Op-Mode 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Register field — Specifies any of the eight data registers. 
Op-Mode field — 


Byte 

Word 

Long word 

Operation 

000 

001 

010 

(<ea>) + (<Dn>)-><Dn> 

100 

101 

110 

(<Dn>) + (<ea>)-><ea> 


Effective Address Field — Determines addressing mode: 

a. If the location specified in a source operand, the all addressing modes are allowed 
as shown: 
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ADD 


ADD 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An* 

001 

reg, number :An 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


* : Word and Long word only. 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


b. If the location specified is a destination operand, then only alterable memory 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

D8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Notes: 1. If the destination is a data register, then it cannot be specified by using the 
destination < ea > mode, but must use the destination Dn mode instead. 

2, ADDA is used when the destination is an address register. ADDI and 
ADDQ are used when the source is immediate data. Most assemblers 
automatically make this distinction. 
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ADDA 


Add Address 


ADDA 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source + Destination-> Destination 

ADDA <ea>,An 
Size = (Word, Long word) 

Add the source operand to the destination address register, and store the 
result in the address register. The size of the operation may be specified to be 
word or long word. The entire destination address register is used regardless 
of the operation size. 


Condition Codes : Not affected 


Instruction Format: 


15 14 13 12 11 10 9 8 


1 


1 


1 


Register 

An 


Op-Mode 


Effective Address 
Mode I Register 


Instruction Fields : 

Register field — Specifies any of the eight address registers. This is always the 
destination. 

Op-Mode field — Specifies the size of the operation: 

Oil — word operation. The source operand is sign-extended to a operand 
and the operation is performed on the address register using all 32 
bits. 

Ill — long word operation. 

Effective Address field — Specifies the source operand. All addressing modes 

are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

001 

reg, number :An 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8(PC, Xn) 

111 

oil 

#<data > 

111 

100 
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ADDI 


Add Immediate 


ADDI 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Immediate Data + Destination Destination 

ADDI #<data>, <ea> 

Size = (Byte, Word, Long word) 

Add the immediate data to the destination operand, and store the result in 
the destination location. The size of the operation may be specified to be byte, 
word, or long word. The size of the immediate data matches the operation 
size. 


Condition Codes 


X N 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V ; Set if an overflow is generated. Cleared otherwise. 
C : Set if a carry is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 

0 

0 

0 

0 

0 

1 

1 

0 

Size 

Effective Address 
Mode i Register 

Word Data 

Byte Data 

Long Word Data (Includes Previous Word) | 


Instruction Fields : 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field ~ Specifies the destination operand. Only data alterable 

addressing modes are allowed as shown: 
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Immediate field — (Data immediately following the instruction): 

If size = 00, then the data is the low order byte of the immediate word. 
If size = 01, then the data is the entire immediated word. 

If size = 10, then the data is the next two immediated words. 
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ADDQ 


Add Quick 


ADDQ 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Immediate Data + Destination Destination 

ADDQ #<data>, <ea> 

Size = (Byte, Word, Long word) 

Add the immediate data to the operand at the destination location. The data 
range is from 1 to 8. The size of the operation may be specified to be byte, 
word, or long word. Word and long word operations are also allowed on the 
address registers, in which case the condition codes are not affected. When 
adding to address registers, the entire destination address register is used, 
regardless of the operation size. 


Condition Codes 


X N 


V C 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a carry is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

The condition codes are not affected if the destination is an address register. 
Instruction Format: 


15 

14 

13 

12 

1110 9 

8 

7 6 

5 4 3 2 1 0 

0 

1 

0 

0 

Data 

0 

Size j 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Data field — Three bits of immediate data, 0, 1~7 representing a range of 8, 1 
to 7 respectively. 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 
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ADDQ 


ADDQ 


Effective Address field — Specifies the destination location. Only alterable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 


reg, number :Dn 

An* 

001 

reg, number :An 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


* : Word and Long word Only. 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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ADDX 


Add Extended 


ADDX 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source + Destination + X Destination 


ADDX 

ADDX 


Dx, Dy 

-(Ax), - (Ay) 


Size = (Byte, Word, Long word) 

Add the source operand to the destination operand along with the extend bit 
and store the result in the destination location. The operands may be 
addressed in two different ways: 

1. Data register to data register: the operands are contained in data 
registers specified in the instruction. 

2. Memory to memory: the operands are addressed with the predecrement 
addressing mode using the address registers specified in the instruction. 

The size of the operation may be specified to be byte, word, or long word. 


Condition Codes 


N : Set if the result is negative. Cleared otherwise. 

Z : Cleared if the result is non-zero. Unchanged otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a carry is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

(NOTE) 

Normally the Z condition code bit is set via programming before the start of 
an operation. This allows successful tests for zero results upon completion of 
multiple-precision operations. 

Instruction Format : 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

□ 

0 

1 

Regisater 

Xv 

□ 

Size 

0 

0 

R/M 

Register 

Xx 
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ADDX 


ADDX 


Instruction Fields : 

Register Xy field — Specifies the destination register: 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement addressing mode. 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

R/M field — Specifies the operand addressing mode: 

0 — The operation is data register to data register. 

1 — The operation is memory to memory. 

Register Xx field — Specifies the source register: 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement addressing mode. 
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AND 

AND Logical 

AND 

Operation 

Source A Destination —> Destination 


Assembler 

AND <ea>,Dn 


Syntax 

: AND Dn, <ea> 


Attributes 

: Size = (Byte, Word, Long word) 


Description 

AND the source operand to the destination operand and store the result in 


the destination location. The size of the operation may be specified to be byte, 
word, or long word. The contents of an address register may not be used as an 
operand. 


Condition Codes : 

X N Z V C 

I - I * I * I 0 I 0 


N : Set if the most significant bit of the result is set. Cleared otherwise, 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 

15 14 13 12 11 10 9_876543210 


ill 

0 

0 

Register 

Op- Mode 

Effective 

1 1 

L_J 


Dn 

Mode 1 Register 


Instruction Fields : 

Register field — Specifies any of the eight data registers. 

Op-Mode field — 

Byte Word Long word Operation 

000 001 010 (<ea>)A(<Dn>)-><Dn> 

100 101 110 (<Dn>) A(<ea>)<ea> 

Effective Address field — Determines addressing mode: 

If the location specified is a source operand then only data addressing modes are 
allowed as shown: 
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TLCS-68000 


AND 


AND 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 


(An) + 



- (An) 


reg, number :An | 

d16(An) 

101 



Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


If the location specified is a destination operand then only alterable memory addressing 
modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number ;An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data > 

- 

- 


Notes: 1. If the destination is a data register, then it cannot be specified by using the 
destination < ea > mode, but must use the destination Dn mode instead. 

2. ANDI is used when the source is immediate data. Most assemblers 
automatically make this distinction. 
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ANDI 


AND Immediate 


ANDI 


Operation 

Assembler 

Syntax 


Immediate Data A Destination Destination 

ANDI #<data>, <ea> 


Attributes 


Size = (Byte, Word, Long word) 


Description 


AND the immediate data to the destination operand and store the result in 
the destination location. The size of the operation may be specified to be byte, 
word, or long. The size of the immediate data matches the operation size. 


Condition Codes : 

X N Z V C 

I - I * I * I 0 I 0 


N : Set if the most significant bit of the result is set. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 


0 

0 

0 

0 

0 

1 

0 

Size 

Effective Address 
Mode 1 Register 

Word Data 

Byte Data 

Long Word Data (Includes Previous Word) | 


Instruction Fields : 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 “■ long word operation. 

Effective Address field — Specifies the destination operand. Only data alterable 

addressing modes are allowes as shown: 
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ANDI 


ANDI 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 


001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number ;Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 




Immediate field — (Data immediately following the instruction): 

If size = 00, then the data is the low order byte of the immediate word. 
If size = 01, then the data is the entire immediate word. 

If size = 10, then the data is the next two immediate words. 
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ANDI to CCR ANDI to CCR 

AND Immediate to Condition Codes 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source A CCR CCR 

ANDI #<data>, CCR 
Size = (Byte) 

AND the immediate operand with the condition codes and store the result in 
the low-order byte of the status register. 


Condition Codes 


X N Z V C 


N 

Z 

V 

C 

X 


Cleared if bit 3 of immediate operand is zero. 
Cleared if bit 2 of immediate operand is zero. 
Cleared if bit 1 of immediate operand is zero. 
Cleared if bit 0 of immediate operand is zero. 
Cleared if bit 4 of immediate operand is zero. 


Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

0 

0 

1 

0 

0 

0 

1 

1 

1 

1 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

Byte Data (8 Bits) 
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ANDI to SR AND Immediate to the Status Register ANDI to SR 

(Privileged Instruction) 


Operation : If supervisor state 

then Source A SR —> SR 
else TRAP; 

Assembler 

Syntax : ANDI #<data>,SR 


Attributes : Size = (Word) 


Description : AND the immediate operand with the contents of the status register and 
store the result in the status register. All bits of the status register are 
affected. 


Condition Codes 


X N Z V C 



N : Cleared if bit 3 of immediate operand is zero. Unchanged otherwise. 
Z : Cleared if bit 2 of immediate operand is zero. Unchanged otherwise. 
V : Cleared if bit 1 of immediate operand is zero. Unchanged otherwise. 
C : Cleared if bit 0 of immediate operand is zero. Unchanged otherwise. 
X : Cleared if bit 4 of immediate operand is zero. Unchanged otherwise. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

[aJ 


LlJ 

LaI 

UJ 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 


Word Data (16 Bits) 
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ASL 

ASR 

Operation 

Assemble 

Syntax 

Attributes 

Description 


Arithmetic Shift 


ASL 

ASR 


: Destination Shifted by < count > Destination 

ASd Dx, Dy 

: ASd # < data >, Dy 

ASd <ea> 
where d is direction, L or R 

: Size = (Byte, Word, Long word) 

: Arithmetically shift the bits of the operand in the direction (L or R) specified. 
The carry bit receives the last bit shifted out of the operand. The shift count 
for the shifting of a register may be specified in two different ways: 

1. Immedicate: the shift count is specified in the instruction 
(shift range, 1~8). 

2. Register: the shift count is contained in a data register specified in the 
instruction (shift count is modulo 64). 

The size of the operation may be specified to be byte, word, or long. The 
content of memory may be shifted one bit only, and the operand size is 
restricted to a word. 

For ASL, the operand is shifted left; the number of positions shifted is the 
shift count. Bits shifted out of the high order bit go to both the carry and the 
extend bits; zeroes are shifted into the low order bit. The overflow bit 
indicates if any sign changes occur during the shift. 



For ASR, the operand is shifted right; the number of positions shifted is the 
shift count. Bits shifted out of the low order bit go to both the carry and the 
extend bits; the sign bit (MSB) is replicated into the high order bit. 
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ASL ASL 

ASR ASR 


Condition Codes: 

X N Z V C 


N : Set if the most significant bit of the result is set. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if the most significant bit is changed at any time during the shift 
operation. Cleared otherwise. 

C : Set according to the last bit shifted out of the operand. Cleared for a shift 
count of zero. 

X : Set according to the last bit shifted out of the operand. Unaffected for a 
shift count of zero. 

Instruction Format (Register Shifts) : 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

1 

□ 

0 

Count 

Register 

H 

Size 

i/r 

0 

0 

Register 


Instruction Fields (Register Shifts) : 

Count/Register field — Specifies shift count or register where count is located: 

If i/r = 0, the shift count is specified in this field. The values 0, 1~7 represent a 

range of 8,1 to 7 respectively. 

If i/r = 1, the shift count (modulo 64) is contained in the data register specified in 

this field. 

dr field — Specifies the direction of the shift: 

0 — shift right. 

1 — shift left. 


Size field — Specifies the size of the operation: 
00 — byte operation. 

01 — word operation. 

10 — long operation. 
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ASL ASL 

ASR ASR 


i/r field — 

If i/r = 0, specifies immediate shift count. 

If i/r = 1, specifies register shift count. 

Register field — Specifies a data register whose content is to be shifted. 

Instruction Format (Memory Shifts): 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

□ 

□ 

1 

_ 

0 

0 

0 

0 

0 

1 

0 

Effective Address 
Mode 1 Register 


Instruction Fields (Memory Shifts): 

dr field — Specifies the direction of the shift: 

0 — shift right 
1 — shfitleft 

Effective Address field — Specifies the operand to be shifted. Only memory alterable 

addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

Oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


1 Addr. Mode 

Mode 

Register 


110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

. d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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Branch Conditionally Bcc 

: If (condition true) then PC + disp PC; 

: Bcc < label > 

: Size = (Byte, Word) 

: If the specified condition is met, program execution continues at location 
(PC) + displacement. The displacement is a twos complement integer which 
counts the relative distance in bytes. The value in the PC is the sign- 
extended instruction location plus two. If the 8-bit displacement in the 
instruction word is zero, then the 16-bit displacement (word immediately 
following the instruction) is used, ‘‘cc” may specify the following conditions: 


cc 

carry clear 

0100 

c 

cs 

carry set 

0101 

c 

eq 

equal 

0111 

z 

GE 

greater or equal 

1100 

N-V + N-V 

GT 

greater than 

1110 

N'V*2 + N*V*Z 

HI 

high 

0010 

c*z 

LE 

less or equal 

1111 

Z + N'V + N*V 

LS 

low or same 

0011 

C + Z 

LT 

less than 

1101 

N*V + N*V 

Ml 

minus 

1011 

N 

NE 

not equal 

0110 

Z 

PL 

plus 

1010 

N 

VC 

overflow clear 

1000 

V. 

VS 

overflow set 

1001 

V 


•: Boolean AND + : Boolean OR N : Boolean NOT N 
Condition Codes : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 8 

7 6 5 4 3 2 1 0 

A 

1 

1 

0 

Condition 

8-bit Displacement 

16-Bit Displacement if 8-Bit Displacement = $00 


Bcc 

Operation 

Assembler 

Syntax 

Attributes 

Description 
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Bcc 


Bcc 


Instruction Fields : 

Condition field — One of fourteen conditions discussed in description. 

8-Bit Displacement field — Twos complement integer specifying the relative distance 
(in bytes) between the branch instruction and the next instruction to be executed 
if the condition is met. 

16-Bit Displacement field — Allows a larger displacement than 8 bits. Uesd only if 
the 8-bit displacement is equal to $00. 

Note: A short branch to the immediately following instruction cannot be generated, 
because it would result in a zero offset, which forces a word branch instruction 
definition. 
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BCHG Test a Bit and Change BCHG 


Operation : ~ (< bit number > of Destination) Z; 

~(< bit number > of Destination) —> < bit number > of Destination 

Assembler BCHG Dn, <ea> 

Syntax : BCHG #<data>, <ea> 

Attributes : Size = (Byte, Long word) 

Description : A bit in the destination operand is tested and the state of the specified bit is 
reflected in the Z condition code. After the test, the state of the specified bit is 
changed in the destination. If a data register is the destination, then the bit 
numbering is modulo 32 allowing bit manipulation on all bits in a data 
register. If a memory location is the destination, a byte is read from that 
location, the bit operation is performed using the bit number, modulo 8, and 
the byte is written back to the location. In all cases, bit zero refers to the least 
significant bit. The bit number for this operation may be specified in two 
different ways: 

1. Immediate — the bit number is specified in a second word of the 
instruction. 

2. Register — the bit number is contained in a data register specified in the 
instruction. 

Condition Codes : 

X N Z V c 



N : Not affected. 

Z : Set if the bit tested is zero. Cleared otherwise. 
V : Not affected. 

C : Not affected. 

X : Not affected. 

Instruction Format (Bit Number Dynamic specified by a register) 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

Register 

Dn 

□ 

0 

□ 

Effective Address 
Mode 1 Register 
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BCHG 


BCHG 


Instruction Fields (Bit Number Dynamic): 

Register field — Specifies the data register whose content is the bit number. 
Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 


1 Addr. Mode 

Mode 

Register 



reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 



Mode 

Register | 

Dn* 

000 


An 

- 

- 

(An) 

010 

. reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number ;An 


* : Long word only; all others are byte only. 


Instruction Format (Bit Number Static, Specified as immedicate data) : 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

1 

0 

0 

0 

0 

1 

Effective Address 
Mode 1 Register 

0 

0 

0 

0 

0 

0 

0 

0 

Bit Number 


Instruction Fields (Bit Number Static) : 

Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn * 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number ;An 


* : Long word only; all others are byte only. 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Bit Number field —Specifies the bit number. 
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BCLR 


Test a Bit and Clear 


BCLR 


Operation 


Assembler 

Syntax 


~(<bitnumber> of Destination)-^Z; 
0 < bit number > of Destination 

BCLR Dn, <ea> 

BCLR #<data>, <ea> 


Attributes 


Size = (Byte, Long word) 


Description 


A bit in the destination operand is tested and the state of the specified bit is 
reflected in the Z condition code. After the test, the specified bit is cleared in 
the destination. If a data register is the destination, then the bit numbering 
is modulo 32 allowing bit manipulation on all bits in a data register. If a 
memory location is the destination, a byte is read from that location, the bit 
operation performed using the bit number, modulo 8, and the byte written 
back to the location. In all cases, bit zero refers to the least significant bit. 
The bit number for this operation may be specified in two different ways: 

1. Immedicate —the bit number is specified in a second word of the 
instruction. 

2. Register —the bit number is contained in a data register specified in the 
instruction. 


Condition Codes : 

X N Z V C 


N : Not affected. 

Z : Set if the bit tested is zero. Cleared otherwise. 
V : Not affected. 

C : Not affected. 

X : Not affected. 

Instruction Format (Bit Number Dynamic, specified in a register) : 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

Register 

Dn 

□ 

□ 

0 

Effective Address 
Mode 1 Register 


Instruction Fields (Bit Number Dynamic) : 

Register field — Specifies the data register whose content is the bit number. 
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BCLR 


BCLR 


Effective Address field — Specifies the destination location. 
Only data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn * 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


* : Long only; all others are byte only. 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 


- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Instruction Format (Bit Number Static, specified as immediate data): 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

1 

0 

0 

0 

□ 

0 

Effective Address 
Mode 1 Register 

D 

D 

D 

D 

D 

11 

D 

D 

Bit Number 


Instruction Fields (Bit Number Static): 

Effective Address field — Specifies the destination location. 
Only data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn* 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


* : Long only; all others are byte only. 


Bit Number field —Specifies the bit number. 
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TLCS-68000 


BKPT Breakpoint BKPT 

Operation : Execute breakpoint acknowledge bus cycle; 

Trap as illegal instruction 

Assembler 

Syntax : BKPT #<data> 

Attributes : Unsized 

Description : This instruction is used to support the program breakpoint function for debug 

monitors and real-time hardware emulators, and the operation will be 
dependent on the implementation. Execution of this instruction will cause 
the TMP68010 to run a breakpoint acknowledge bus cycle (all function codes 
driven high) and zeros on all address lines. ’ 

Whether the breakpoint acknowledge bus cycle is terminated with 
DTACK, BERR, or VPA, the processor always 

takes an illegal instruction exception. During exception processing, a debug 
monitor can distinguish eight different software breakpoints by decoding the 
field in the BKPT instruction. 

For the TMP68000 and TMP68008, this instruction causes an illegal 
instruction exception but does not run the breakpoint acknowledge bus cycle. 

Condition Codes : Not affected. 

Instruction Format: 



Instruction Fields : 

BKPT # = Immediate data (value = 0~7), encodes 8 software breakpoints. 
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BRA Branch Always BRA 

Operation : PC + disp-^PC 

Assembler 

Syntax : BRA < label > 

Attributes : Size = (Byte, Word) 

Description : Program execution continues at location (PC) + displacement. The 
displacement is a twos complement integer, which counts the relative 
distance in bytes. The value in the PC is the instruction location plus two. If 
the 8-bit displacement in the instruction word is zero, then the 16-bit 
displacement (word im.mediately following the instruction) is used. 

Condition Codes : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 5 4 3 2 1 0 


3 

1 

0 

0 

0 

0 

0 

8-Bit Displacement 


16-Bit Displacement if 8-Bit Displacement = $00 


Instruction Fields : 

8-Bit Displacement field — Two complement integer specifying the relative distance 
(in bytes) between the branch instruction and the next instruction to be executed 

16-Bit Displacement field — Allows a larger displacementthan 8 bits. Used only if the 
8-bit displacement is equal to $00. 

Note: A short branch to the immediately following instruction cannot be generated 

because it would result in a zero offset, which forces a word branch instruction 
definition. 
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BSET Test a Bit and Set BSET 

operation : ~ (< bit number > of Destination) ^ Z; 

1 < bit number > of Destination 

Assembler BSET Dn, <ea> 

Syntax ; BSET #<data>, <ea> 

Attributes : Size = (Byte, Long word) 

Description : A bit in the destination operand is tested, and the state of the specified bit is 
reflected in the Z condition code. After the test, the specified bit is set in the 
destination. If a data register is the destination, then the bit numbering is 
modulo 32, allowing bit manipulation on all bits in a data register. If a 
memory location is the destination, a byte is read from that location, the bit 
operation performed using the bit number, modulo 8, and the byte written 
back to the location. Bit zero refers to the least significant bit. The bit 
number for this operation may be specified in two different ways: 

1. Immediate — the bit number is specified in a second word of the 
instruction. 

2. Register — the bit number is contained in a data register specified in the 
instruction. 

Condition Codes : 


X N Z V C 



N : Not affected. 

Z : Set if the bit tested is zero. Cleared otherwise. 

V : Not affected. 

C : Not affected. 

X : Not affected. 

Instruction Format (Bit Number Dynamic, specified in a register) : 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

0 I 0 I 0 I 0 I Register I 1 I 1 I 1 I Effective Address 
I I I I _ III Mode I Register 

Instruction Fields (Bit Number Dynamic): 

Register field — Specifies the data register whose content is the bit number. 
Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 
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BSET 


BSET 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 


Register | 

Dn * 

000 


An 

- 

1 

(An) 

010 


(An) + 

oil 


- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


* : Long word only; all others are byte only. 


Instruction Format (Bit Number Static, specified as immediate data): 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

1 

0 

0 

0 

1 

1 

Effective Address 
Mode 1 Register 

0 

0 

0 

0 

0 

0 

0 

0 

Bit Number 


Instruction Fields (Bit Number Static) : 

Bit Number field — Specifies the bit number. 

Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn * 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


* : Long word only; all others are byte only. 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

oao 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 
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BSR 


Branch to subroutine 


BSR 


Operation : SP — 4 SP; PC (SP); PC + disp -^PC 
Assembler 

Syntax : BSR < label > 


Attributes 


Size = (Byte, Word) 


Description : The long word address of the instruction immediately following the BSR 
instruction is pushed onto the system stack. Program execution then 
continues at location (PC)+ displacement. The displacement in a twos 
complement integer which counts the relative distances in the bytes. The 
value in the PC is the instruction location plus two. If the 8-bit displacement 
in the instruction word is zero, then the 16-bit displacement (word 
immediately following the instruction) is used. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

5 

8 

7 6 5 4 3 2 1 0 

A 

1 

1 

0 

0 

0 

0 

1 

8-Bit Displacement 

16-Bitdisplacement if 8-Bit Displacement = $00 


Instruction Fields : 

8-Bit Displacement field — Twos complement integer specifying the relative distance 
(in bytes) between the branchinstruction and the next instruction to be executed. 

16-Bit Displacement field — Allows a larger displacement than 8 bits. Used only if the 
8-bit displacement is equal to $00. 

Note: A short subroutine branch to the immediately following instruction cannot be 

generated because it would result in a zero offset, which forces a word branch 
instruction definition. 
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BTST 


Test a Bit 


BTST 


~(< bit number > of Destination)—>Z; 

BTST Dn, <ea> 

BTST #<ciata>, <ea> 

Size = (Byte, Long word) 

A bit in the destination operand is tested, and the state of the specified bit is 
reflected in the Z condition code. If a data register is the destination , then the 
bit numbering is modulo 32, allowing bit manipulation on all bits in a data 
register. If a memory location is the destination, a byte is read from that 
location, and the bit operation performed using the bit number, modulo 8, 
with zero referring to the least significant bit. The bit number for this 
operation may be specified in two different ways: 

1. Immediate — the bit number is specified in a second word of the 
instruction. 

2. Register — the bit number is contained in a data register specified in 
theinstruction. 

Condition Codes : 


X N Z V C 



N : Not affected. 

Z : Set if the bit tested is zero. Cleared otherwise. 
V : Not affected. 

C : Not affected. 

X : Not affected. 

Instruction Format (Bit Number Dynamic, specified in a register) : 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

Register 

Dn 

1 

0 

0 

Effective Address 
Mode 1 Register 


Instruction Fields (Bit Number Dynamic) : 

Register field — Specifies the data register whose content is the bit number. 

Effective Address field — Specifies the destination location. Only data addressing modes 
are allowed as shown: 


Operation 

Assembler 

Syntax 

Attributes 

Description 
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BTST 


BTST 


Addr. Mode 

Mode 

Register 


110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 


111 

oil 

#<data> 


100 


Addr. Mode 

Mode 

Register 

Dn * 

000 

reg, number :Dn 

An 

- 

- 

(An) 


reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


* : Long word onlj'-; all others are byte only. 


Instruction Format (Bit Number Static, specified as immediate data) : 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

0 

0 

1 

0 

0 

0 

0 

0 

Effective Address 
Mode 1 Register 

0 

0 

0 

0 

0 

0 

0 

0 

Bit Number 


Instruction Fields (Bit Number Static) : 

Bit Number field — Specifies the bit number. 

Effective Address field —Specifies the destination location. Only data addressing modes 
are allowed as shown; 


Addr. Mode 

Mode 

Register 

Dn * 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 1 

reg, number :An 

- (An) 

100 1 

reg, number :An 

die (An) 

101 

reg, number :An 


* : Long word only; all others are byte only. 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number ;An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

Oil 

#<data> 

- 

- 
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CHK Check Register Against Bounds CHK 


Operation 

Assembler 

Syntax 

Attributes 


If Dn < 0 or Dn > Source then TRAP; 

CHK <ea>,Dn 
Size = (Word) 


Description 


The content of the low order word in the data register specified in the 
instruction is examined and compared to the upper bound. The upper bound 
is a twos complement integer. If the register value is less than zero or greater 
than the upper bound, then the processor initiates exception processing. The 
vector number is generated to reference the CHK instruction exception 
vector. 


Condition Codes 


X 

N 

z 

V 

c 

□ 

LU 

E 

E 

E 


N : Set if Dn<0; cleared if Dn> Source. Undifined otherwise. 

Z : Undefined. 

V : Undefined. 

C : Undefined. 

X : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

□ 

0 

0 

Register 

Dn 

1 

1 

0 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Register field — Specifies the data register whose content is checked. 
Effective Address field — Specifies the upper bound operand word. 
Only data addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 
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CLR 


Clear an Operand 


CLR 


Operation : 0 ^Destination 

Assembler 

Syntax : CLR < ea > 

Attributes : Size = (Byte, Word, Long word) 

Description : The destination is cleared to all zero. The size of the operation may be 
specified to be byte, word, or long word. 

Condition Codes : 


X 

N 

z 

V 

c 

□ 

H 


H 



N : Always cleared. 
Z : Always set. 

V : Always cleared. 
C : Always cleared. 
X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 7 6 

5 4 3 2 1 0 

0 

1 

0 

0 

0 

1 

0 

Size 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Size field — Specifies the size of the operation. 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field —Specifies the destination location. Only data alterable addressing 
modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 


- 

- 

#<data > 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 


- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 


Note : A memory destination is read before it is written to. 
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CMP 


Compare 


CLP 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination —Source 

CMP <ea>,Dn 

Size = (Byte, Word, Long word) 

Subtract the source operand from the specified data register and set the 
condition codes according to the result; the data register is not changed. The 
size of the operation may be byte, word, or long word. 


Condition Codes 


X N Z V C 



N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 
C : Set if a borrow is generated. Cleared otherwise. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

□ 

0 

1 

□ 

Register 

Dn 

Op-Mode 

Effective Address 
Mode i Register 


Instruction Fields : 

Register field — Specifies the destination data register. 

Op-Mode field — 

Byte Word Long word Operation 
000 001 010 Dn-(<ea>) 

Effective Address field — Specifies the source operand. All addressing modes are allowed 
as shown: 
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CMP 


CMP 




Register 

d8 (An, Xn) 

110 


Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 


reg, number :Dn 

An * 


reg, number :An 

(An) 

010 


(An) + 



- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number ;An 


* ; Word and Long word only. 


Note: CMPA is used when the destination is an address register. CMPI is used when 

the source is immediate data. CMPM is used for memory to memory compares. 
Most assemblers automatically make this distinction. 
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CMPA Compare Address CMPA 

Operation : Destination — Source 

Assembler 

Syntax : CMPA <ea>,An 

Attributes : Size = (Word, Long word) 

Description : Subtract the source operand from the destination address register and set the 

condition codes according to the result; the address register is not changed. 
The size of the operation may be specified to be word or long word. Word 
length source operands are sign extended to 32-bit quantities before the 
operation is done. 

Condition Codes : 

X N Z V C 



N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a borrow is generated. Cleared otherwise. 

X : Not affected. 

Instruction Format: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

10 11 Register Op-Mode Effective Address 

I I I I An _ Mode | Register 

Instruction Fields : 

Register field — Specifies the destination data register. 

Op-Mode field — Specifies the size of the operation: 

Oil — word operation. The source operand is sign-extened to a long operand and 
the operation is performed on the address register using all 32 bits. 

Ill — long operation. 

Effective Address field —Specifies the source operand. All addressing modes are 
allowed as shown: 


VMPU-108 






TOSHIBA 


TLCS-68000 


CMPA 


CMPA 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

001 

reg, number :An 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data > 

111 

100 
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CMPI 


Compare Immediate 


CMPI 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination — Immediate Data 

CMPI #<data>, <ea> 

Size = (Byte, Word, Long word) 

Subtract the immediate data from the destination operand and set the 
condition codes according to the result; the destination location is not 
changed. The size of the operation may be specified to be byte, word, or long 
word. The size of the immediate.data matches the operation size. 


Condition Codes : 

X N Z V C 

I f* r~* r~* I 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 
C : Set if a borrow is generated. Cleared otherwise. 

X : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 


0 

0 

0 

1 

1 

0 

0 

Size 

Effective Address 
Mode i Register 

Word Data 

Byte Data 

Long word Data | 


Instruction Fields : 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the destination operand. Only data alterable 
addressing modes are allowed as shown: 
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CMPI 


CMPI 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 


Immediate field — (Data immediately following the instruction) : 

If size = 00, then the data is the low order byte of the immediate word. 
If size = 01, then the data is the entire immeidate word. 

If size = 10, then the data is the next two immediate words. 
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Compare Memory CMPM 

Destination — Source 

CMPM (Ax) + ,(Ay) + 

Size = (Byte, Word, Long word) 

Subtract the source operand form the destination operand, and set the 
condition codes according to the results; the destination location is not 
changed. The operands are always addressed with the postincrement 
addressing mode, using the address registers specified in the instruction. 
The size of the operation may be specified to be byte, word, or long word. 

Condition Codes : 

X N Z V C 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 
C : Set if a borrow is generated. Cleared otherwise. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 





Register Ay 


Size 


E 


Register Ax 


Instruction Fields : 

Register Ay field — (always the destination) Specifies an address register for the 
postincrement addressing mode. 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Register Ax field — (always the source) Specifies an address register for the 
postincrement addressing mode. 


CMPM 

Operation 

Assembler 

Syntax 

Attributes 

Description 
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DBcc 

Operation 

Assembler 

Syntax 

Attributes 

Description 


Test Condition, Decrement, 
and Branch 


DBcc 


: If condition false then (Dn — 1 Dn; if Dn =?^ — 1 then PC + disp PC): 


DBcc Dn, < label > 

Size = (Word) 

This instruction is a looping primitive of three parameters: a condition, a 
counter (data register), and a displacement. The instruction first tests the 
condition to determine if the termination condition for the loop has been met, 
and if so, no operation is performed. If the termination condition is not true, 
the low order 16-bits of the counter data register are decremented by one. If 
the result is —1, the counter is exhausted and execution continues with the 
next instruction. If the result is not equal to —1, execution continues at the 
location indicated by the current value of the PC plus the sign-extended 16- 
bit displacement. The value in the PC is the current instruction location plus 
two. 


“cc” may specify the following conditions: 






cc 

carry clear 

0100 

c 

cs 

carry set 

0101 

c 

EQ 

equal 

0111 

z 

F 

never true 

0001 

0 

GE 

greater or equal 

1100 

N*V + N*V 

GT 

greater than 

1110 

N'V*Z + N'V'Z 

HI 

high 

0010 

c*z 

LE 

less or equal 

1111 

Z + N-V + N-V 

LS ' 

low or same 

0011 

C + Z 

LT 

less than 

1101 

N*V + N«V 

Ml 

minus 

1011 

N 

NE 

not equal 

0110 

Z 

PL 

plus 

1010 

N 

T 

always true 

0000 

1 

VC 

overflow clear 

1000 

V 

VS 

overflow set 

1001 

V 


• = Boolean AND + = Boolean OR N = Boolean NOTN 
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DBcc 


DBcc 


Condition Codes : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 98 

7 

6 

5 

4 

3 

2 1 0 

0 

1 

0 

□ 

Condition 

□ 

□ 

0 

0 

1 

Register 

Displacement 


Instruction Fields : 

Condition field — One of the sixteen conditions discussed in discription. 

Register field — Specifies the data register which is the counter. 

Displacement field — Specifies the distance of the branch (in bytes). 

Notes: 1. The terminating condition is like that definedby the UNTIL loop constructs of 

high-level languages. For example: DBMI can be stated as “decrement and 
branch until minus”. 

2. Most assemblers accept DBRA for DBF for use when no condition is required for 
termination of a loop. 

3. There are two basic ways of entering a loop: at the beginning or by branching to 
the trailing DBcc instruction. If a loop structure terminated with DBcc is 
entered at the beginning, the control index count must be one less than the 
number of loop executions desired. This count is useful for indexed addressing 
modes and dynamically specified bit operations. However, when entering a loop 
by branching directly to the trailing DBcc instruction, the control index should 
equal the loop execution count. In this case, if a zero count occurs, the DBcc 
instruction will not branch, causing a complete bypass of the main loop. 
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DIVS 


Signed Divide 


DIVS 


Operation 

Assembler 

Syntax 

Attributes 


Destination/Source -^Destination 

DIVS <ea>, Dn 32/16->16r:16g 

Size = (Word) 


Description : Divide the destination operand by the source and store the result in the 
destination. The operation is performed using signed arithmetic. 

The destination operand is a long word and the source operand is a word. The 
result is 32-bits, such that the quotient is in the lower word (least significant 
16 bits)of the destination and the remainder is in the upper word (most 
significant 16 bits) of the destination. Note that the sign of the remainder is 
the same as the sign of the dividend. 

Two special conditions may arise during the operation: 

1. Division by zero causes a trap. 

2. Overflow may be detected and set before completion of the instruction. If 
overflow is detected, the condition is flagged but the operands are 
unaffected. 


Condition Codes: 

X N Z V C 

I - T"* |~* T"* I 0 


N : Set if the quotient is negative. Cleared otherwise. Undefined if overflow 
or divide by zero. 

Z : Set if the quotient is zero. Cleared otherwise. Undefined if overflow or 
divide by zero. 

V : Set if division overflow is detected. Cleared otherwise. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

□ 

0 

0 

1 

0 

Register 

Dn 

□ 

0 

0 

Effective Address 
Mode 1 Register 
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TOSHIBA 


TLCS-68000 


DIVS DIVS 

Instruction Fields : 

Register field — Specifies any of the eight data registers. This field always specifies the 
destination operand. 

Effective Address field — Specifies the source operand. Only data addressing modes are 
allowed as shown: 




Note: Overflow occurs if the quotient is larger than a 16-bit signed integer. 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

-* 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 
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TOSHIBA 


TLCS-68000 


DIVU 


Unsigned Divide 


DIVU 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination/Source -^Destination 

DIVU <ea>,Dn 32/16->16r:16q 

Size = (Word) 

Divide the destination operand by the source and store the result in the 
destination. The operation is performed using unsigned arithmetic. 

The destination operand is a long word and the source operand is a word. The 
result is 32-bits, such that the quotient is in the lower word (least significant 
16-bits) of the destination and the remainder is in the upper word (most 
significant 16 bits) of the destination. Note that the sign of the remainder is 
the same as the sign of the dividend. 

Two special conditions may arise during the operation: 

1. Division by zero causes a trap. 

2. Overflow may be detected and set before completion of the instruction. If 
overflow is detected, the condition is flagged but the operands are 
unaffected. 


Condition Codes : 

X N Z V C 

I ^ I * I * I * I ^ 


N : Set if the quotient is negative. Cleared otherwise. Undefined if overflow 
or divide by zero. 

Z : Set if the quotient is zero. Cleared otherwise. Undefined if overflow or 
divideby zero. 

V : Set if division overflow is detected. Cleared otherwise. 

C : Always cleared. 

X : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

1 

0 

0 

0 

Register 

Dn 

0 

□ 

□ 

Effective Address 
Mode 1 Register 
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DIVU 


DIVU 


Instruction Fields : 

Register field — Specifies any of the eight data registers. This field always spesifies the 
destination operand. 

Effective Address field — Specifies the source operand. Only data addressing modes 
are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

011 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Note: Overflow occurs if the quotient is larger than a 16-bit unsigned integer. 
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TLCS-68000 


Exclusive OR Logical EOR 

: Source © Destination ^ Destination 

: EOR Dn, <ea> 

: Size = (Byte, Word, Long word) 

: Exclusive OR the source operand to the destination operand and store the 
result in the destination location. The size of the operation may be specified 
to be byte, word, or long word. This operation is restricted to data registers as 
the source operand. The destination operand is specified in the effective 
address field. 

Condition Codes: 

X N Z V C 
- * * * 0 

N : Set if the most significant bit of the result is set. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format (word form) : 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

□ 

0 

1 

1 

Register 

Dn 

Op-Mode 

Effective Address 
Mode 1 Register 


EOR 

Operation 

Assembler 

Syntax 

Attributes 

Description 


Instruction Fields : 

Register field — Specifies any of the eight data registers. 

Op-Mode field — 

Byte Word Long word Operation 

100 101 110 <ea> © <Dx><ea> 

Effective Address field —Specifies the destination operand. Only data alterable 
addressing modes are allowed as shown: 
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EOR 


EOR 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number ;Dn 

An 

- 

- 

(An) 

010 


(An) + 

oil 


-(An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


1 Addr. Mode 

Mode 

Register 


110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Note: Memory to data register operations are not allowed. EORI is used when the 

source is immediate data. Most assemblers automatically make this 
distinction. 
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Exclusive OR Immediate EORI 

Immediate Data © Destination Destination 

EORI #<data>, <ea> 

Size = (Byte, Word, Long word) 

Exclusive OR the immediate data to the destination operand and store the 
result in the destination location. The size of the operation may be specified 
to be byte, word, or long word. The immediate data matches the operation 
size. 

Condition Codes : 

X N Z V C 
- I * I * I 0 I 0 

N : Set if the most significant bit of the result is set. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

0 

0 

0 

1 

0 

1 

0 

Size 

Effective Address 
Mode i Register 

Word Data (16 Bits) 

Byte Data (8Bits) 

Long word Data (32 Bits, including Previous Word) | 


Instruction Fields ; 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the destination operand. Only data alterable 
addressing modes are allowed as shown: 


EORI 

Operation 

Assembler 

Syntax 

Attributes 

Description 
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EORI 


EORI 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 


(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 


Immediate field — (Data immediately following the instruction): 

If size = 00, then the data is the low order byte of the immediate word. 
If size = 01, then the data is the entire immediate word. 

If size = 10, then the data is next two immediate words. 
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EORI to CCR Exclusive OR Immediate 

to Condition Code 


EORIto CCR 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source © CCR ^ CCR 

EORI #<data>, CCR 

Size = (Byte) 

Exclusive OR the immediate operand with the condition codes and store the 
result in the low-order byte of the status register. 


Condition Codes 


X N 


N 

Z 

V 

c 

X 


Changed if bit 3 of immediate operand is one. 
Changed if bit 2 of immediate operand is one. 
Changed if bit 1 of immediate operand is one. 
Changed if bit 0 of immediate operand is one. 
Changed if bit 4 of immediate operand is one. 


Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

1 

0 

1 

0 



0 

0 

0 

0 

0 

0 




0 

”o~ 



0 

Byte Data (8 Bits) 
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EORI to SR Exclusive OR Immediate EORI to SR 

to the Status Register (Privileged Instruction) 


Operation 


Assembler 

Syntax 

Attributes 

Description 


If supervisor state 

then Source © SR SR 
else TRAP; 

EORI # < data >, SR 

Size = (Word) 

Exclusive OR the immediate operand with the contents of the status register 
and store the result in the status register. All bits of the status register are 
affected. 


Condition Codes 


X N Z V C 


N 

Z 

V 

c 

X 


Changed if bit 3 of immediate operand 
Changed if bit 2 of immediate operand 
Changed if bit 1 of immediate operand 
Changed if bit 0 of immediate operand 
Changed if bit 4 of immediate operand 


IS one. 
is one. 
is one. 
is one. 
is one. 


Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 


0 

0 

0 

1 

0 

1 

0 

0 

1 

1 


’ 


0 


Word Data (16 Bits) 


VMPU-124 








TOSHIBA 
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EXG 


Exchange Register 


EXG 


Operation 

Assembler 

Syntax 


Attributes 


Xx^Xy 

EXG Dx, Dy 
EXG Ax, Ay 
EXG Dx, Ay 

Size = (Long word) 


Description : Exchange the contents of two registers. This exchange is always a long (32- 
bit) operation. Exchange works in three modes: 

1. Exchange data registers. 

2. Exchange address registers. 

3. Exchange a data register and an address register. 


Condition Codes : Not affected. 


Instruction Format: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


d 

d 

H 

H 

Register Xx 

m 

Op-Mode 

Register Xy 


Instruction Fields : 

Register Xx field — Specifies either a data register or an address register depending on 
the mode. If the exchange is between data and addrress registers, this field always 
specifies the data register. 

Op-Mode field — Specifies whether exchanging: 

01000 — data registers. 

01001 — address registers. 

10001 “ data register and address register. 

Register Xy field — Specifies either a data register or an address register depending on 
the mode. If the exchange is between data and address registers, this field always 
specifies the address register. 


VMPU-125 




TOSHIBA 
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Sign Extend EXT 

Destination Sign-extended Destination 
EXT Dn 

Size = (Word, Long word) 

Extend the sign bit of a data register from a byte to a word, or from a word to 
a long word, depending on the size selected. If the operation is word, bit [7] of 
the designated data register is copied to bits [15:8] of that data register. If the 
operation is long, bit [15] of the designated data register is copied to bits 
[31:16] of the data register. 

Condition Codes : 

X N Z V C 

- I * I * I 0 I 0 

N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 7 6 

5 

4 

3 

2 1 0 

E 

m 

H 

0 

n 

E 

E 

Op-Mode 

E 

E 

E 

Register Dn 


Instruction Fields : 

Op-Mode field — Specifies the size of the sign-extension operation: 

010 — Sign-extend low order byte of data register to word. 

Oil — Sign-extend low order word of data register to long word. 

Register field — Specifies the data register whose content is to be sign-extended. 


EXT 

Operation 

Assembler 

Syntax 

Attributes 

Description 
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TLCS-68000 


ILLEGAL Take Illegal Instruction Trap ILLEGAL 

Operation : SSP —2-^88?; Vector Offset-^(88P); | 

88P - 4 ^ 88P; PC^(88P); 

88P - 2 88P; 8R^(88P); 

Illegal Instruction Vector Address PC 

Assembler 

8yntax : ILLEGAL 

Attributes : Unsized 

Description : This bit pattern causes an illegal instruction exception. All other illegal 
instruction bit patterns are reserved for future exception of the 
instruction set. 

The TMP68010 will first write the exception vector offset and format code 
to the system stack followed by the PC and 8R to complete a 4-word 
exception stack frame. 

Condition Codes : Not affected. 

Instruction Format: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 
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JMP 


Jump 


TLCS-68000 

JMP 


Operation : 

Assembler 

Destination Address PC 

Syntax : 

JMP < ea > 

Attributes : 

Unsized 

Description : 

Program execution continues at the effective address specified by the 
instruction. The address is specified by the control addressing modes. 

Condition Codes 

: Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 


1 

0 

0 

' 

1 

□ 

0 

□ 

□ 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the address of the next instruction. Only control 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 



reg, number :An 

Abs.W 

111 

000 

Abs.L 


001 

d16(PC) 

111 

010 



oil 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

- 

- 

- (An) 

- 

- 

die (An) 

101 

reg, number :An 
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TOSHIBA 


TLCS-68000 


JSR 


Jump to Subroutine 


JSR 


Operation : SP—4—>SP; PC-^(SP); 

Destination Address PC 

Assembler 

Syntax : JSR <ea> 

Attributes : Unsized 

Description : The long word address of the instruction immediately following the JSR 
instruction is pushed onto the system stack. Program execution then 
continues at the address specified in the instruction. 

Condition Codes : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

□ 

0 

0 

1 

□ 

0 

0 

□ 

0 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the address of the next instruction. Only control 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

- 

- 

- (An) 

- 

- 

die (An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

- 

- 
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TOSHIBA 

TLCS-68000 

LEA 

Load Effective Address 

LEA 

Operation 

<ea> ->An 


Assembler 
Syntax : 

LEA < ea >, An 


Attributes 

Size = (Long word) 


Description : 

The effective address is loaded into the specified address register, 
of the address register are affected by this instruction. 

All 32 bits 

Condition Codes 

: Not affected. 


Instruction Format: 



15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

Register 

An 

□ 

□ 

0 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Register field — Specifies the address register which is to be loaded with the effective 
address. 

Effective Address field — Specifies the address to be loaded into the address register. 
Only control addressingmodes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 


- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

- 

- 

-(An) 

- 

- 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register | 


110 


Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

- 

- 
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LINK Link and Allocate LINK 

Operation : SP —4~^SR; An^(SR); 

SP -> An; SP + disp -> SP 

Assembler 

Syntax : LINK An, #< displacement > 

Attributes : Size = Unsized 

Description : The current content of the specified address register is pushed onto the stack. 

After the push, the address register is loaded from the updated stack pointer. 
Finally, the 16-bit sign-extended displacement operand is added to the stack 
pointer. The content of the address register occupies one long word on the 
stack. A negative displacement is specified to allocate stack area. 

Condition Codes : Not affected. 

Instruction Format: 



Instruction Fields : 

Register field — Specifies the address register through which the link is to be 
constructed. 

Displacement field — Specifies the twos complement integer which is to be added to the 
stack pointer. 

Note: LINK and UNLK can be used to maintain a linked list of local data and 

parameter areas on the stack for nested subroutine calls. 


VMPU-131 





TOSHIBA 


TLCS-68000 


LSL 

LSR 

Operation 

Assembler 

Syntax 

Attributes 

Description 


Logical Shift 


LSL 

LSR 


: Destination Shifted by < count > Destination 

LSd Dx, Dy 

: LSd # < data >, Dy 

LSd <ea> 

where d is direction, L or R 

: Size = (Byte, Word, Long word) 

: Shift the bits of the operand in the direction (L or R) specified. The carry bit 
receives the last bit shifted out of the operand. The shift count for the 
shifting of a register may be specified in two different ways: 

1. Immediate — the shift count is specified in the instruction (shift range 

2. Registe — the shift count is contained in a data register specified in the 

instruction (shift count modulo 64). 

The size of the operation may be specified to be byte, word, or long word. The 
content of memory may be shifted one bit only, and the operand size is 
restricted to a word. 

For LSL, the operand is shifted left; the number of positions shifted is the 
shift count. Bits shifted out of the high order bit go to both the carry and the 
extend bits; zeroes are shifted into the low order bit. 


LSL : 


0 


Operand 


0 



For LSR, the operand is shifted right; the number of positions shifted is the shift 
count. Bits shifted out of the low order bit go to both the carry and the extend 
bits; zeroes are shifted into the high order bit. 
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LSL LSL 

LSR LSR 


LSR : 


Condition Codes: 

X N Z V C 

I * I * I * I 0 I 


Operand 




N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C ; Set according to the last bit shifted out of the operand. Cleared for a shift 
count of zero. 

X : Set according to the last bit shifted out of the operand. Unaffected for a 
shift count of zero. 

Instruction Format (Register Shifts) : 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

□ 

□ 

E 

Count/ 

Register 

H 

Size 

0 

E 

0 

Register 


Instruction Field (Register Shifts); 

Count/Register field — 

If i/r = 0, he shift count is specified in this field. The values 0,1~7 represent a range 
of 8,1 to 7 respectively. 

If i/r = 1, the shift count (modulo 64) is contained in the data register specified in 
this field. 

dr field — Specifies the direction of the shift: 

0 — shift right. 

1 — shift left. 

Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation 
i/r field — 

If i/r = 0, Specifies immediate shift count. 

If i/r = 1, Specifies register shift count. 

Register field — Specifies a data register whose content is to be shifted. 
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LSL LSL 

LSR LSR 


Instruction Format (Memory Shifts) : 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

□ 

□ 

□ 

E 

B 

B 

B 

H 

□ 

1 

Effective Address 
Mode 1 Register 


instruction Fields (Memory Shifts): 

dr field -- Specifies the direction of the shift: 

0 — shift right. 

1 — shift left. 

Effective Address field —Specifies the operand to be shifted. Only memory alterable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

Oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 
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TLCS-68000 


MOVE 


Move Data from Source to Destination 


MOVE 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source Destination 

MOVE <ea>, <ea> 

Size = (Byte, Word, Long word) 

Move the content of the source to the destination location. The data is 
examined as it is moved, and the condition codes set accordingly. The size of 
the operation may be specified to be byte, word, or long word. 


Condition Codes 


X N_Z V_C 


n 

□ 

□ 




N : Set if the result is negative. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 12 

11 10 9 8 7 6 

5 4 3 2 1 0 

0 

0 

Size 

Destination i 

Register | Mode 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Size field — Specifies the size of the operand to be moved: 

01 — byte operation. 

11 — word operation. 

10 — long word operation. 

Destination Effective Address field — Specifies the destination location. Only data 
alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number ;An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 
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TLCS-68000 


MOVE 


MOVE 


Source Effective Address field — Specifies the source operand. All addressing modes are 
allowed as shown: 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data > 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 


reg, number :Dn 

An* 



(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16 (An) 

101 

reg, number :An 


* : For byte size operation, address register direct is not allowed. 

Notes: 1. MOVEA is used when the destination is an address register. Most assemblers 
automatically make this distinction. 

2. MOVEQ can also be used for certain operations on data registers. 










TOSHIBA 


TLCS-68000 


MOVE from OCR 


Move from the 
Condition Code Register 


MOVE from CCR 


Operation 

Assembler 

Syntax 

Attributes 

Description 


CCR -^Destination 

MOVE CCR, <ea> 

Size = (Word) 

The content of the status register is moved to the destination location. The 
source operand is a word, but only the low order byte contains the 
conditioncodes. The upper byte is all zeroes. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

0 

0 

□ 

0 

□ 

1 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

A n 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

- 

- 

d8(PC, Xn) 

- 


#<data > 

- 

- 


Notes: MOVE from CCR is a word operation. ANDI, ORI, and EORI to CCR are byte 
operations. 
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MOVE to OCR Move to the Condition Code Register MOVE to CCR 


Operation 

Assembler 

Syntax 

Attributes 

Description 


SourceCCR 

MOVE <ea>,CCR 
Size = (Word) 

The content of the source operand is moved to the condition codes. The source 
operand is a word, but only the low order byte is used to update the condition 
codes. The upper byte is ignored. 


Condition Codes 


X N Z V C 



N : Set the same as bit 3 of the source operand. 

Z : Set the same as bit 2 of the source operand. 

V : Set the same as bit 1 of the source operand. 

C : Set the same as bit 0 of the source operand. 

X : Set the same as bit 4 of the source operand. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

0 

1 

0 

0 

□ 

1 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the location of the source operand. Only data 
addressing modes are allowed as shown: 
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MOVE to OCR 


MOVE to OCR 


Addr. Mode 

Mode 

Register | 

d8(An, Xn) 

110 


Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


Notes: MOVE to OCR is a word operation. ANDI, ORI, and EORI to OCR are byte 
operations. 
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MOVE to SR Move to the Status Register MOVE to SR 

(Privileged Instruction) 


Operation 

If supervisor stsate 
then Source-»SR 
else TRAP; 

Assembler 

Syntax 

MOVE <ea>,SR 

Attributes 

Size = (Word) 

Description 

The content of the source operrand is moved to the status registe. The 
sourrce operarnd is a word and all bits of the status register are affected. 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

□ 

0 

0 

0 

0 

0 

0 

0 

□ 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the locaation of the source operand. Only data 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8(PC, Xn) 

111 

oil 

#<data > 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

d16(An) 

101 

reg, number :An 
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MOVE from SR Move from the Status Register MOVE from SR 


Operation 

Assembler 

SR-^Destination 

Syntax : 

MOVE SR, <ea> 

Attributes : 

Size = (Word) 

Description : 

The content of the status register is moved to the destination location. The 
operand size is a word. 

Condition Codes 

: Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

r 

0 

0 

0 

0 

0 

0 

r 

V 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the destination location. Only data alterrable 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg, number :Dn 

An 

- 

- 

(An) 

010 

reg, number :An 

(An) + 

oil 

reg, number :An 

- (An) 

100 

reg, number :An 

die (An) 

101 

reg, number :An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg, number :An 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 


Note: A memory destination is read beforre it is wrritten to. 
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Move from SR Move from the Status Register Move from SR 

(Privileged Instruction) 


Operation 

: If supervisor state 

then SR Destination 
else TRAP; 

Assembler 

vSyntax 

: MOVE SR, <ea> 

Attributes 

: Size = (Word) 

Description 

: The content of the status register is moved to the destination location. 
The operand size is a word. 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

1-3 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

0 

0 

0 

0 

1 

0 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Effective Address field — Specifies the destination location. Only data alterable 
addressing modes are allowed as shown: 


Add. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. Number;An 

Abs. W 

111 

000 

Abs. L 

111 

001 

d16(PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data> 

- 

- 


Add. Mode 

Mode 

Register 

Dn 

000 

reg. NumberiAn 

An 

- 

- 

(An) 

010 

reg. Number:An 

(An) + 

oil 

reg. Number:An 

-(An) 

100 

reg. NumberiAn 

die (An) 

101 

reg. NumberiAn 


Note: Use the MOVE from CCR instruction to access only the condition codes. 
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Move USP 


Move User Stack Pointer Move USP 

(Privileged Instruciton) 


Operation 


Assembler 

Syntax 

Attributes 

Description 


If supervisor state 

then USP An or An USP 
else TRAP; 

MOVE USP, An 
MOVE An, USP 

Size = (Long word) 

The contents of the user stack pointer are transferred to or from the specified 
address register. 


Condition Codes : Not affected. 


Instruction Format: 



14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

[t 

□ 

0 

0 

□ 

1 

□ 

0 

0 

□ 

1 

0 

dr 

Address 

Register 


Instruction Fields ; 

dr field — Specifies the direction of transfer: 

0 — transfer the address register to the USP. 

1 -- transfer the USP to the address register. 

Register field — Specifies the address register to or from which the user stack pointer is 
to be transferred. 
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MOVEA 


Move Address 


MOVEA 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source -^Destination 

MOVEA < ea >, An 
Size = (Word, Long ’word) 

Move the content of the source to the destination address register. The size of 
the operation may be specified to be word or long word. Word size source 
operands are sign extended to 32-bit quantities before the operation is done. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

0 

Size 

Destinaiton 

Register 

0 


0 

Source 

Mode 1 Register 


Instruction Fields : 

Size field — Specifies the size of the operand to be moved: 

11 — Word operation. The source operand is sign-extended to a long operand and 
all 32 bits are loaded into the address register. 

10 — Long word operation. 

Destination Register field — Specifies the destination address register. 

Source Effective Address field — Specifies the location of source operand. All addressing 
modes are allowed as shown: 


Add. Mode 

Mode 

Register 

Dn 

000 

- 

An 

001 

- 

(An) 

010 

reg. NumbenAn 

(An) + 

oil 

reg. Number:An 

-(An) 

100 

reg. NumberiAn 

d16(An) 

101 

reg. NumberiAn 


Add. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. NumberiAn 

Abs.W 

111 

000 

Abs. L 

111 

001 

d16(PC) 

111 

010 

d8(PC, Xn) 

111 

oil 

#<data> 

111 

100 
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MOVEC 

Move to/from Control Register MOVEC 

(Privileged Instruction) 

Operation 

If supervisor state 

then Rc -> Xn or Xn —> Rc 
else TRAP; 

Assembler 

MOVEC Rc, Xn 

Syntax 

: MOVEC Xn, Rc 

Attributes 

: Size = (Long word) 

Description 

: Copy the contents of the specified control register (Rc) to the specified 
general register or copy the contents of the specified general register to 
the specified control register. This is always a 32-bit transfer even 
though the control register may be implemented with fewer bits. 
Unimplemented bits are read as zeros. 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

1 

0 

0 

1 

1 

1 

0 

0 

1 

1 

1 

1 

0 

1 

0 

A/D 

Register 

Control Register 


Instruction Fields: 

dr field — Specifies the direction of transfer: 

0 — control register to general register 
1 — general register to control register 
A/D field — Specifies the type of general register: 

0 — data register 
1 — address register 

Register field — Specifies the register number. 

Control Register field ~ Specifies the control register. 

Hex Control Register 

000 Source Function Code (SFC) register. 

001 Destination Function Code (DFC) register. 

800 User Stack Pointer (USP). 

801 Vector Base Register (VBR). 

All other codes cause an illegal instruction exception. 
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MOVEM 


Move Multiple Registers MOVEM 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Registers -^Destination 
Source -^Registers 

MOVEM register list, <ea> 

MOVEM < ea >, register list 

Size = (Word, Long 'word) 

Selected registers are transferred to or from consecutive memory locations 
starting at the location specified by the effective address. A register is 
transferred if the bit corresponding to that register is set in the mask field. 
The instruction selects how much of each register is transferred; either the 
entire long word can be moved or just the low order word. In the case of a 
word transfer to the registers, each word is sign-extended to 32 bits 
(including data registers) and the resulting long word loaded into the 
associated register. MOVEM allows three forms of address modes: the 
control modes, the predecrement mode, or the postincrement mode. If the 
effective address is in one of the control modes, the registers are transferred 
starting at the specified address and up through higher addresses. The order 
of transfer is from data register 0 to data register 7, then from address 
register 0 to address register 7. 

If the effective address is the predecrement mode, only a register to memory 
operation is allowed. The registers are stored starting at the specified 
address minus the operand length (2 or 4) and down through lower addresses. 
The order of storing is from address register 7 to address register 0, then from 
data register 7 to data register 0. The decremented address register is 
updated to contain the address of the last word stored. 

If the effective address is the postincrement mode, only a memory to register 
operation is allowed. The registers are loaded starting at the specified 
address and up through higher addresses. The order of loading is the same as 
for the control mode addressing. The incremented address register is 
updated to contain the address of the last word loaded plus the operand 
length (2 or 4). 


Condition Codes : Not affected. 
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MOVEM 


MOVEM 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 


□ 

0 

0 

□ 

dr 

0 

0 

□ 

0 

Effective Address 
Mode 1 Register 


Register List Mask 


Instruction Fields : 

dr field — Specifies the direction of the transfer: 

0 — register to memory. 

1 — memory to register. 

Sz field — Specifies the size of the registers being transferred: 

0 -- word transfer. 

1 — long word transfer. 

Effective Address field — Specifies the memory address to or from which the 
registers are to be moved. For register to memory transfers, only control 
alterable addressing modes or the predecrement addressing mode are 
allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

- 

- 

-(An) 

100 

reg. number:An 

die (An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberiAn 

Abs.W 

111 

000 

Abs.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


For memory to register transfers, only control addressing modes or the 
postincrement addressing mode are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. numberiAn 

(An) + 

oil 

reg. numberiAn 

-(An) 

- 

- 

die (An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberiAn 

Abs.W 

111 

000 

Abs.L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

in 

oil 

#<data> 

- 

- 
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MOVEM 


MOVEM 


Register List Mask field — Specifies which registers are to be transferred. 
The low order bit corresponds to the first register to be transferred; the 
high bit corresponds to the last register to be transferred. Thus, both for 
control modes and for the postincrement mode addresses, the mask 
correspondence is 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

A7 

A6 

A5 

A4! 

A3 

A2 

A1 

AO 

D7 

D6 

D5 

D4 

D3 

D2 

D1 

DO 


while for the predecrement mode addresses, the mask correspondence is 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


DO 

D1 

D2 

D3 

D4 

D5 

D6 

D7 

AO 

A1 

A2 

A3 

A4 

A5 

A6 

A7 


Note: 

An extra read bus cycle occurs for memory operands. This accesses an 
operand at one address higher than the last register image required. 
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MOVEP 

Move Peripheral Data 

MOVEP 

Operation : 

Source ^Destination 


Assembler 
Syntax : 

MOVEP Dx, die (Ay) 

MOVEP die (Ay), Dx 


Attributes 

Size = (Word, Long word) 


Description : 

Data is transferred between a data register and alternate bytes of memory, 
starting at the location specified and incrementing by two. The high order 
byte of the data register is transferred first and the low order byte is 
transferred last. The memory address is specified using the address register 
indirect plus 16-bit displacement addressing mode. This instruction is 
designed to work with 8-bit peripherals on a 16-bit data bus. If the address is 
even, all the transfers are made on the high order half of the data bus; if the 
address is odd, all the transfers are made on the low order half of the data 


bus. On an 8-bit or 32-bit bus, the instruction still accesses every other byte. 
Example : Long transfer to/from an even address. 

Byte organization in register 

31_24 23_16 15 _87_0 


Hi-Order 

Mid-Upper 

Mid-Lower 

Low-Order 


Byte organization in memory (low address at top) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


Hi-Order 


Mid-Upper 


Mid-Lower 


Low-Order 
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MOVEP 


MOVEP 


Example : Word transfer to/from an odd address. 

Byte organization in register 

31 24 23 16 15 _^8 7_0 




High-Order 

Low-Order 


Byte organization in memory (low address at top) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



High-Order 


Low-Order 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 

4 

3 

2 1 0 


0 

0 

0 

Data 

Register 

Op-Mode 

0 

0 

1 

Address 

Register 

Displacement 


Instruction Fields : Data Register field — Specifies the data register to or from which the 
data is to be transferred. 

Op-Mode field — Specifies the direction and size of the operation: 

100 — transfer word from memory to register. 

101 — transfer long from memory to register. 

110 — transfer word from register to memory. 

111 — transfer long from register to memory. 

Address Register field — Specifies the address register which is used 
in the address register indirect plus displacement addressing mode. 
Displacement field — Specifies the displacement which is used in 
calculating the operand address. 
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MOVEQ 


Move Quick 


MOVEQ 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Immediate Data —> Destination 

MOVEQ #<data>,Dn 
Size = (Long word) 

Move immediate data to a data register. The data is contained in an 8-bit 
field within the operation word. The data is sign-extended to a long word 
operand and all 32 bits are transferred to the data register. 


Condition Codes 


X N Z V C 
* * 0 0 

N : Set if the result is negative. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 6 5 4 3 2 1 0 

0 

1 

□ 

□ 

Register 

Dn 

0 

Data 


Instruction Fields : Register field — Specifies the data register to be loaded. 

Data field — 8 bits of data which are sign extended to a long word 
operand. 
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MOVES 

Move Alternate Address Space MOVES 

(Privileged Instruction) 

Operation 

: If supervisor state 

then Xn Destination [DFC] or Source [SFC] Xn 
else TRAP; 

Assembler 

Syntax 

: MOVES Xn, <ea> 

MOVES <ea>,Xn 

Attributes 

: Size = (Byte, Word, Long word) 

Description 

: Move the byte, word, or long word operand from the specified general 
register to a location within the address space specified by the destination 
function code (DFC) register. Or, move the byte, word, or long word 
operand from a location within the address space specified by the source 
function code (SFC) register to the specified general register. 

If the destination is a data register, the source operand replaces the 
corresponding low-order bits of that data register. If the destination is an 
address register, the source operand is sign-extended to 32 bits and then 
loaded into that address register. 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

1 

1 

1 

0 

Size 

Effective 

Mode 

Address 

Register 

A/D 

Register 

dr 

~ 

0 

0 





0 





Instruction Fields : Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the source or destination location 
within the alternate address space. Only alterable memory 
addressing modes are allowed as shown: 

A/D field — Specifies the type of general register: 

0 — data register. 

1 — address register. 
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MOVES 


MOVES 


Register field — Specifies the register number, 
dr field — Specifies the direction of the transfer: 

0 — from < ea > to general register. 

1 — from general register to < ea >. 

MOVES.x An,(An) + 
or 

MOVES.x An,-(An) 

where An is the same address register for both source and 
destination and is an undefined operation. The value stored in 
memory is undefined. 

NOTE 


On the TMP68010 implementations, the value stored is the incremented or the 
decremented value of An. This implementation may not appear on future devices. 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. numberrAn 

d16(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. number:An 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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MULS 


Signed Multiply 


MULS 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source *Destination Destination 

MULS <ea>,Dn 16X16-^32 

Size = (Word) 

Multiply two signed operands yielding a signed result. The operation is 
performed using signed arithmetic. 

The multiplier and multiplicand are both word operands and the result is 
long word operand. A register operand is taken from the low order word, the 
upper word is unused. All 32 bits of the product are saved in the destination 
data register. 


Condition Codes 


X 

N 

Z 

V 

c 

□ 


N 

lIj 

LL 


N : Set if the result is negative. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

1110 9 

8 

7 

6 

5 4 3 2 1 0 


□ 

0 

0 

Register 

Dn 

1 

□ 

1 

Effective Address 
Mode 1 Register 
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MULS 


MULS 


Instruction Fields : Register field — Specifies one of the data registers. This field always 
specifies the destination. 

Effective Address field — Specifies the source operand. Only data 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. numberiDn 

An 

- 

- 

(An) 

010 

reg. numberiAn 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. number:An 

d16(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

111 

010 

d8(PC, Xn) 

111 

oil 

#<data> 

111 

100 
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MULU 


Unsigned Multiply 


MULU 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source *Destination -^Destination 

MULS <ea>,Dn 16Xl6-»32 

Size = (Word) 

Multiply two unsigned operands yielding a unsigned result. The operation is 
performed using unsigned arithmetic. 

The multiplier and multiplicand are both word operands and the result is a 
long word operand. A register operand is taken from the low order word, the 
upper word is unused. All 32 bits of the product are saved in the destination 
data register. 


Condition Codes 


X N Z V C 

I * I * I 0 1 ^ 


N : Set if the result is negative. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

1 

□ 

0 

0 

Register 

Dn 

0 

□ 

□ 

Effective Address 
Mode 1 Register 
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MULU 


MULU 


Instruction Fields : Register field -- Specifies one of the data registers. This field always 
specifies the destination. 

Effective Address field — Specifies the source operand. Only data 
addressing modes are allowed as shown: 
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NBCD Negate Decimal with Extend NBCD 


Operation 

Assembler 

Syntax 

Attributes 

Description 


0 — Destinationio — XDestination 


NBCD <ea> 

Size = (Byte) 

The operand addressed as the destination and the extend bit are 
subtracted from zero. The operation is performed using decimal 
arithmetic. The result is saved in the destination location. This 
instruction produces the tens complement of the destination if the extend 
bit is clear, the nines complement if the extend bit is set. This is a byte 
operation only. 


Condition Codes 


X 

N 

Z 

V 

c 

LJ 

U 

LU 

0 

L*J 


N : Undefined. 

Z : Cleared if the result is non-zero. Unchanged otherwise. 

V : Undefined. 

C : Set if a borrow (decimal) was generated. Cleared otherwise. 

X : Set the same as the carry bit. 

Note: 

Normally the Z condition code bit is set via programming before the start 
of an operation. This allows successful tests for zero results upon completion 
of multiple precision operations. 

Instruction Format : 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

1 ^ 

0 

0 

0 

0 

0 

Effective Address 
Mode 1 Register 
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TOSHIBA 


TLCS-68000 


NBCD 


NBCD 


Instruction Fields : Effective Address field — Specifies the destination operand. Only 
data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number:Dn 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. numbenAn 

-(An) 

100 

reg. numbenAn 

d16(An) 

101 

reg. number:An 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. number:An 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data > 

- 

- 
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TOSHIBA 


TLCS-68000 


NEG 


Negate 


NEG 


Operation 

Assembler 

Syntax 

Attributes 

Description 


0 — Destination-^Destination 

NEG <ea> 

Size = (Byte, Word, Long word) 

The operand addressed as the destination is subtracted from zero. The 
result is stored in the destination location. The size of the operation may 
be specified to be byte, word, or long word. 


Condition Codes 


X N Z V C 

"* I * ] * I * I 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 
C : Cleared if the result is zero. Set otherwise. 

X : Set the same as the carry bit. 


Instruction Format: 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

□ 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 
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TOSHIBA 


TLCS-68000 


NEG 


NEG 


Instruction Fields : Size field — Specifies the size of the operation. 

00 — byte operation 
01 — word operation 
10 — long word operation 

Effective Address field — Specifies the destination operand. Only 
data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number:Dn 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. numberiAn 

d16(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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TOSHIBA 


TLCS-68000 


NEGX 


Negate with Extend 


NEGX 


Operation 

Assembler 

Syntax 

Attributes 

Description 


0 — Destination — X Destination 


NEGX <ea> 

Size = (Byte, Word, Long word) 

The operand addressed as the destination and the extend bit are 
subtracted from zero. The result is stored in the destination location. The 
size of the operation may be specified to be byte, word, or long word . 


Condition Codes 


X N Z V C 



N : Set if the result is negative. Cleared otherwise. 

Z : Cleared if the result is non-zero. Unchanged otherwise. 

V : Set if overflow is generated. Cleared otherwise. 

C : Set if a borrow is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

Note: 

Normally the Z condition code bit is set via programming before the start 
of an operation. This allows successful tests for zero results upon completion 
of multiple-precision operations. 

Instruction Format: 


15 14 13 12 11 10 9 876543210 


0 

1 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 
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TLCS-68000 


NEGX 


NEGX 


Instruction Fields : Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long operation. 

Effective Address field — Specifies the destination operand. Only 
data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number:Dn 

An 

- 

- 

(An) 

010 

reg. numberiAn 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. number:An 

d16(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 


- 

#<data> 

- 

- 
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TOSHIBA 


TLCS-68000 

NOP 

No Operation 

NOP 

Operation 

: None 


Assebler 

Syntax 

: NOP 


Attributes 

: Unsized 


Description 

: No operation occurs. The processor state, other than the program counter, 


is unaffected. Execution continues with the instruction following the NOP 
instruction. The NOP instruction does not complete execution until all 
pending bus cycles are completed. This allows synchronization of the 
pipeline to be accomplished, and prevents instruction overlap. 

Condition Codes : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

□ 

0 

0 

□ 

□ 

□ 

0 

0 

□ 

□ 

1 

0 

0 

0 
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TLCS-68000 


NOT 

Logical Complement 

NOT 

Operation : 

~ Destination -^Destination 


Assembler 

Syntax : 

NOT <ea> 


Attributes : 

Size = (Byte, Word, Long word) 


Description 

The ones complements of the destination operand is taken and the result is 
stored in the destination location. The size of the operation may be 
specified to be byte, word, or long word. 

Condition Codes 




X N Z V C 
“** 00 ' 

N : Set if the result is negative. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 14 13 12 11 10 9876543210 



□ 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 
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TLCS-68000 


NOT 


NOT 


Instruction Fields : Size field — Specifies the size of the operation. 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the destination operand. 
Only data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number:Dn 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. number:An 

dl6(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. number:An 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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TOSHIBA 


TLCS-68000 


OR 


Inclusive OR Logical 

OR 

Operation 

: Source V Destination Destination 


Assembler 




Syntax 

: OR 

<ea>, Dn 



OR 

Dn, <ea> 


Attributes 

: Size = 

(Byte, Word, Long word) 


Description 

: Inclusive OR the source operand to the destination operand and store the 


result in the destination location. The size of the operation may be 
specified to be byte, word, or long word. The contents of an adress register 
may not be used as an operand. 


Condition Codes 

X N Z V C 
* * 0 0 

N : Set if the most significant bit of the result is set. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

□ 

0 

0 

0 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 
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TLCS-68000 


OR 


OR 


Instruction Fields : Register field — Specifies any of the eight data registers. 

Op-Mode field — 

Byte Word Long word Operation 

000 001 010 (<ea>)\/(<Dn>)<Dn> 

100 101 110 (<Dn>)V(<ea>)-><ea> 

Effective Address field — 

If the location specified is a source operand then only data addressing 
modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number: Dn 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. numberiAn 

-(An) 

100 

reg. number:An 

die (An) 

101 

reg. numberiAn 


If the location specified is a destination operand then only memory 
alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. numberiAn 

-(An) 

100 

reg. numberiAn 

die (An) 

101 

reg. numberiAn 


Notes: 1. If the destination is a data register, then it cannot be specified by using the 
destination < ea > mode, but must use the destination Dn mode instead. 

2. ORI is used when the source is immediate data. Most assemblers 
automatically make this distinction. 
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TOSHIBA 


TLCS-68000 


ORI 


Inclusive OR Immediate 


ORI 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Immediate Data V Destination Destination 

ORI #<data>, <ea> 

Size = (Byte, Word, Long word) 

Inclusive OR the immediate data to the destination operand and store the 
result in the destination location. The size of the operation may be 
specified tobe byte, word, or long word. The size of the immediate data 
matches the operation size. 


Condition Codes 


X N Z V C 

- I * 1 * I 0 1 0 


N : Set if the most significant bit of the result is set. Cleared otherwise. 
Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 


0 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 

Word Data 

Byte Data 

Long word Data 
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TOSHIBA 


TLCS-68000 


ORI ORI 

Instruction Fields : Size field — Specifies the size of the operation. 

00 — byte operation. 

01 — word operation. 

10 — long operation. 

Effective Address field — Specifies the destination operand. Only data 
alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. numberiDn 

An 

- 

- 

(An) 

010 

reg. numberiAn 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. number:An 

d16(An) 

101 

reg. numberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. number:An 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Immediate field ~ (Data immediately following the instruction): 

If size = 00, then the data is the low order byte of the immediate 
word. 

If size = 01, then the data is the entire immediate word. 

If size = 10, then the data is the next two immediate words. 
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TOSHIBA 


TLCS-68000 


ORI to CCR Inclusive OR Immediate to Condition Codes ORI to CCR 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Source V CCR CCR 

ORI #<data>, CCR 

Size = (Byte) 

Inclusive OR the immediate operand with the condition codes and store 
the result in the low-order byte of the status register. 


Condition Codes 


X N 


V C 


N 

Z 

V 

c 

X 


: Set if bit 3 of immediate operand is one. 
: Set if bit 2 of immediate operand is one. 
: Set if bit 1 of immediate operand is one. 
: Set if bit 0 of immediate operand is one. 
: Set if bit 4 of immediate operand is one. 


Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 
Unchanged otherwise. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

0 

0 


0 



0 

0 

0 

0 

0 

0 


0 

0 

0 


0 



Byte Data (8 Bits) 


VMPU-171 







TOSHIBA 


TLCS-68000 


ORI to SR ORI to SR 

Inclusive OR Immediate to the Status Register 
(Privileged Instruction) 


Operation 


Assembler 

Syntax 

Attributes 

Description 


If supervisor state 
then Source V SR —> SR 
else TRAP; 

ORI # < data >, SR 

Size = (Word) 

Inclusive OR the immediate operand with the contents of the status 
register and store the result in the status register. All bits of the status 
register are affected. 


Condition Codes 


X N Z V C 



N : Set if bit 3 of immediate operand is one. Unchanged otherwise. 
Z : Set if bit 2 of immediate operand is one. Unchanged otherwise. 
V : Set if bit 1 of immediate operand is one. Unchanged otherwise. 
C : Set if bit 0 of immediate operand is one. Unchanged otherwise. 
X : Set if bit 4 of immediate operand is one. Unchanged otherwise. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 

E 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 


Word Data (16 Bits) 
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TOSHIBA 


TLCS-68000 


PEA 

Push Effective Address 

PEA 

Operation : 

SP-4-^SP; EA^(SP) 


Assembler 

Syntax : 

PEA <ea> 


Attributes : 

Size = (Long word) 


Description : 

The effective address is computed and pushed onto the stack, 
address is pushed onto the stack. 

A long word 

Condition Codes 

: Not affected. 


Instruction Format: 



15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

□ 

1 

0 

0 

□ 

0 

0 

0 

0 

1 

Effective Address 
Mode 1 Register 


Instruction Fields : Effective Address field — Specifies the address to be pushed on to the 
stack. Only control addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. numberrAn 

(An) + 

- 

- 

-(An) 

- 

- 

d16(An) 

101 

reg. number:An 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. numberiAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

111 

010 

d8(PC, Xn) 

111 

oil 

#<data> 

- 

- 
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TOSHIBA 


TLCS-68000 


RESET Reset External Devices RESET 

(Privileged Instruction) 


Operation : If supervisor state 

then Assert RESET Line 
else TRAP; 


Assembler 

Syntax 


RESET 


Attributes 


Unsized 


Description 


The reset line is asserted for 124 clocks, causing all external devices to be 
reset. The processor state, other than the program counter, is unaffected 
and execution continues with the next instruction. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

E 

E 

E 

E 

B 

B 

B 

0 

B 

B 

B 

B 

B 

B 

B 

B 
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TOSHIBA 


TLCS-68000 


ROL 

ROR 

Operation 

Assembler 

Syntax 

Attributes 

Description 


ROL 


ROR 


Rotate (Without Extend) ROL 

ROR 


: Destination Rotated by < count > Destination 

: ROd Dx, Dy 

ROd #<data>,Dy 

ROd <ea> 

where d is direction, L or R 

: Size = (Byte, Word, Long word) 

: Rotate the bits of the operand in the direction (L or R) specified. The 
extend bit is not included in the rotation. The rotate count for the rotation 
of a register may be specified in two different ways: 

1. Immediate — the rotate count is specified in the instruction (rotate 

range, 1~8). 

2. Register — the rotate count is contained in a data register specified in 

the instriuction. 

The size of the operation may be specified to be byte, word, or long word. 
The content of memory may be rotated by one bit only and the operand size 
is restricted to a word. 

For ROL, the operand is rotated left; the number of positions rotated is the 
rotate count. Bits rotated out of the high order bit go to both the carry bit 
and back into the low order bit. The extend bit is not modified or used. 






IcJ 

L_. 


Operand 

, I 

r I 



For ROR, the operand is rotated right; the number of positions rotated is 
the rotate count. Bits shifted out of the low order bit go to both the carry 
bit and back into the high order bit. The extend bit is not modified or used. 





rvi 

^ Operand 
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TLCS-68000 


ROL ROL 

ROR ROR 


Condition Codes 


X N Z V C 

* * 0 * 

N : Set if the most significant bit of the result is set. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V ; Always cleared. 

C : Set according to the last bit rotated out of the operand. Cleared for a 
rotate count of zero. 

X : Not affected. 

Instruction Format (Register Rotate) : 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

□ 

□ 

0 

Rotate/ 

Register 

H 

Size 

0 

□ 

0 

Register 


Instruction Fields (Register Rotate) : 

Rotate/Register field — 

If i/r = 0, the rotate count is specified in this field. The values 0, 1—7 
represent a range of 8,1 to 7 respectively. 

If i/r = 1, the rotate count (modulo 64) is contained in the data register 
specified in this field. 

dr field — Specifies the direction of the rotate: 

0 — rotate right 
1 ~ rotate left 

Size field — Specifies the size of the operation: 

00 — byte operation 
01 — word operation 
10 — long operation 
i/r field — 

If i/r = 0, Specifies immediate rotate count. 

If i/r = 1, Specifies register rotate count. 

Register field — Specifies a data register whose content is to be rotated. 
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TOSHIBA 


TLCS-68000 


ROL ROL 

ROR ROR 


Instruction Format (Memory Rotate) 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

r 

□ 

1 

0 

0 

0 

□ 

dr 

□ 

0 

Effective Address 
Mode 1 Register 


Instruction Fields (Memory Rotate) : 

dr field — Specifies the direction of the rotate: 

0 — rotate right 
1 — rotate left 

Effective Address field — Specifies the operand to be rotated. 
Only memory alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

- 


An 

- 

- 

(An) 

010 

reg. numbenAn 

(An) + 

oil 

reg. number:An 

-(An) 

100 

reg. numbenAn 

d16 (An) 

101 

reg. numbenAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. numbenAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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TOSHIBA 


TLCS-68000 


ROXL 

ROXR 

Operation 

Assembler 

Syntax 

Attributes 

Description 


ROXL 


Rotate with Extend 


ROXL 

ROXR 


: Destination Rotated with X by < count > —^ Destination 

: ROXd Dx, Dy 

ROXd #<data>,Dy 

ROXd <ea> 

where d is direction, L or R 

: Size = (Byte, Word, Long word) 

: Rotate the bits of the destination operand in the direction specified. The 
extend bit (X) is included in the rotation. The rotate count for the rotation 
of a register may be specified in two different ways: 

1. Immediate — the rotate count is specified in the instruction (rotate 

range, 1~8). 

2. Register — the rotate count (modulo 64) is contained in a data register 

specified in the instriuction. 

The size of the operation may be specified to be byte, word, or long word. 
The content of memory may be rotated one bit only and the operand size is 
restricted to a word. 

For ROXL, the operand is rotated left; the number of positions rotated is 
the rotate count. Bits rotated out of the high order bit go to both the carry 
and extend bits; the previous value of the extend bit is rotated into the low 
order bit. 



For ROXR, the operand is rotated right; the number of positions shifted is 
the rotate count. Bits rotated out of the low order bit go to both the carry 
and extend bits; the previous value of the extend bit is rotated into the 
high order bit. 
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TLCS-68000 


ROXL 

ROXL 

ROXR 

ROXR 

ROXR : 




Condition Codes : 

X N Z V C 

I * I * I * I 0 I ^ 


N ; Set if the most significant bit of the result is set. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Always cleared. 

C : Set according to the last bit rotated out of the operand. Set to the value 
of the extend bit for a rotate count of zero. 

X : Set according to the last bit rotated out of the operand. Unaffected for a 
rotate count of zero. 

Instruction Format (Register Rotate) : 


15 

14 

13 

12 

1110 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

1 

1 

0 

Rotate/ 

Register 

H 

Size 

i/r 

1 

0 

Register 


Instruction Fields (Register Rotate) : 

Rotate/Register field — 

If i/r = 0, the rotate count is specified in this field. The values 0, 1~7 
represent a range of 8,1 to 7 respectively. 

If i/r = 1, the rotate count (modulo 64) is contained in the data register 
specified in this field. 

dr field — Specifies the direction of the rotate: 

0 — rotate right 
1 — rotate left 
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TLCS-68000 


ROXL ROXL 

ROXR ROXR 


Size field — Specifies the size of the operation: 

00 — byte operation. 

01 — word operation. 

10 — long word operation, 
i/r field — 

If i/r = 0, specifies immediate rotate count. 

If i/r = 1, specifies register rotate count. 

Register field — Specifies a data register whose content is to be rotated. 

Instruction Format (Memory Rotate) : 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

□ 

1 

□ 

0 

0 

1 

0 

H 

0 

□ 

Effective Address 
Mode 1 Register 


Instruction Fields (Memory Rotate) : 

dr field — Specifies the direction of the rotate: 

0 — rotate right 
1 — rotate left 

Effective Address field — Specifies the operand to be rotated. Only memory 
alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. number:An 

Ads.W 

111 

000 

Ads.L 

111 

001 

die (PC) 

- 

- 

d8(PC, Xn) 

. - 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

- 

- 

An 

- 

- 

(An) 

010 

reg. number:An 

(An) + 

oil 

reg. number;An 

-(An) 

100 

reg. number:An 

d16 (An) 

101 

reg. numberiAn 
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TLCS-68000 


RTD 


Return and Deallocate Parameters RTD 


Operation 

Assembler 

Syntax 

Attributes 


: (SP)->PC; SP + 4 + dl6->SP 

: RTD #< displacement > 

: Unsized 


Description 


The program counter is pulled from the stack. The previous program 
counter value is lost. After the program counter is read from the 
stack, the displacement value (16 bits) is sign-extended to 32 bits and 
added to the stack pointer. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

LC 


LC 





lIj 

M 

[Z 


N 

Ld 

LZ 

[o_ 

ZJ 


Displacement 


Instruction Fields : Displacement field — 

Specifies the twos complement integer which is to be sign-extended 
and added to the stack pointer. 
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RTE Return from Exception RTE 

(Privileged Instruction) 

Operation : If supervisor stat 

then((SP)~»SR; SP + 2->SP; (SP)->PC; SP + 4~>SP;) 
else TRAP; 

Assembler 

Syntax : RTE 

Attributes : Unsized 

Description : The status register and program counter are pulled from the system stack. 

The previous status register and program counter are lost. All bits in the 
status register aare affected. 

Condition Codes : Set according to the content of the word on the stack. 

Instruction Format: 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 
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RTE Return from Exception (Privileged Instruction) RTE 


Operation 


Assembler 

Syntax 


If supervisor stat 

then((SP)->SR; SP + 2->SP; (SP)-^PC; SP + 4->SP; 
restore state and deallocate 
stack according to (SP)) 
else TRAP; 

RTE 


Attributes 


Unsized 


Description 


The processor state information in the exception stack frame on top of 
the stack is loaded into the processor. The stack format field in the 
format/offset word is examined to determine how much information 
must be restored. 


Condition Codes 


Set according to the content of the word on the stack. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

LL 


L±J 


m 



[jj 

LjJ 


Q 

LjJ 

0 

lL 


LiJ 


Format/Offset Word (in stack frame) : 

15 12 11 10 9 0 


Format 

3 


Vector Offset 


Instruction Fields : Format field — This 4-bit field defines the amount of information to 
be restored. 

0000 — Short Format, only four words are to be removed from 
the top of the stack. The status register and program 
counter are loaded from the stack frame. 

1000 — TMP68010 Long Format, 29 words are removed from the 
top of the stack. 

Any others — the processor takes a format error exception. 
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RTR 


Return and Restore Condition Codes 


RTR 


Operation 


(SP)-^CCR; SP + 2-^SP; 
(SP)^PC; SP + 4->SP 


Assembler 

Syntax 


RTR 


Attributes 


Unsized 


Description 


The condition codes and program counter are pulled from the stack. The 
previous condition codes and program counter are lost. The supervisor 
portion of the status register is unaffected. 


Condition Codes : Set according to the content of the word on the stack. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

LC 


LU 

LC 

m 

m 


LC 


m 

bJ 

m 

LC 



m 
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RTS 


Return from Subroutine 


RTS 


Operation 

Assembler 

Syntax 

Attributes 

Description 


(SP)->PC; SP + 4->SP 

RTS 

Unsized 

The program counter is pulled from the stack. The previous program 
counter is lost. 


Condition Codes : Not affected. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

1 

6 

5 

4 

3 

2 

1 

0 


LU 

LlJ 

iXi 

LjJ 

□ 


ill 

LlJ 

m 

□ 


LoJ 

m 

LiJ 

□ 
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SBCD 


Subtract Decimal with Extend SBCD 


Operation 

Assembler 

Syntax 

Attributes 


Destinationio — Sourceio — XDestination 

SBCD Dx, Dy 

SBCD ~(Ax), ~(Ay) 

Size = (Byte) 


Description : Subtract the source operand from the distination operand with the extend 
bit and store the result in the destination location. The subtraction is 
performed using decimal arithmetic. The operands may be addressed in 
two different ways: 

1. Data register to data register: The operands are contained in the data 
registers specified in the instruction. 

2. Memory to memory: The operands are addressed with the predecrement 
addressing mode using the address registers specified in the 
instruction. 

This operation is a byte operation only. 


Condition Codes 


X 

N 

z 

V 

c 

M 

[U 

LiJ 


Ld 


N : Undefined. 

Z : Cleared if the result is non-zero. Unchanged otherwise. 

V : Undefined. 

C : Set if a borrow (decimal) is generated. Cleared otherwose. 

X Set the same as the carry bit. 

Note: 

Normally the Z condition code bit is set via programming before the start 
of an operation. This allows successful tests for zero results upon completion 
of multiple-precision operation. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 

1 

0 

0 

0 

Register 

Dy/Ay 

1 


0 

0 

0 

R/M 

Register 

Dx/Ax 
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SBCD 

Instruction Fields : 


SBCD 


Register Dy/Ay field — Specifies the destination register. 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement 
addressing mode. 

R/M filed -- Specifies the operand addressing mode: 

0 — The operation is data register to data register 
1 — The operation is memory to memory 
Register Dx/Ax field — Specifies the source register. 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement 
addressing mode. 
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See 

Set Aeeording to Condition 

See 

Operation 

: If Condition True 



then 1 s ^Destination 



else Os ^Destination 


Assembler 



Syntax 

See <ea> 


Attributes 

Size = (Byte) 


Description 

The specified condition code is tested; if the condition is 

true, the byte 


specified by the effective address is set to TRUE (all ones), otherwise that 
byte is set to FALSE (all zeroes), “cc” may specify the following conditions: 


cc 

carry clear 

0100 

c 

cs 

carry set 

0101 

c 

EQ 

equal 

0111 

z 

F 

never true 

0001 

0 

GE 

greater or equal 

1100 

N-V + N-V 

GT 

greater than 

1110 

N-V-Z + N-V-Z 

HI 

high 

0010 

cz 

LE 

less or equal 

1111 

Z + N-V + N-V 

LS 

low or same 

0011 

c + z 

LT 

less than 

1101 

N-V + N-V 

Ml 

minus 

1011 

N 

NE 

not equal 

0110 

Z 

PI 

plus 

1010 

N 

T 

always true 

0000 

1 

VC 

overflow clear 

1000 

V 

VS 

overflow set 

1001 

V 


• = Boolean AND + = Boolean OR N = Boolean NOT N 


Condition Codes : Not affected. 
Instruction Format : 


15 

14 

13 

12 

11 10 9 8 

7 

6 

5 4 3 2 1 0 

0 

1 

0 

0 

Condition 

0 

1 

Effective Address 
Mode 1 Register 
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See 


See 


Instruction Fields : Condition field — One of sixteen conditions discussed in description. 

Effective Address field — Specifies the location in which the 
true/false byte is to be stored. Only data alterable addressing modes 
are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. number;Dn 

An 

- 

- 

(An) 

010 

reg. numberiAn 

(An) + 

oil 

reg. numberrAn 

~(An) 

100 

reg. numberrAn 

d16(An) 

101 

reg. numberrAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. numberrAn 

Ads.W 

111 

000 

Ads.L 

111 

001 

d16(PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Note: 


1. An arithmetic one and zero result may be generated by following the See 
instruction with a NEG instruction. 
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STOP 


Load Status Register and Stop STOP 

(Privileged Instruction) 


Operation 


Assembler 

Syntax 

Attributes 

Description 


If supervisor state 

then (Immediate Data SR; STOP) 
else TRAP ; 

STOP #<data> 

Unsized 

The immediate operand is moved into the entire status register; the 
program counter is advanced to point to the next instruction and the 
processor stops fetching and executing instructions. Execution of 
instructions resumes when a trace, interrupt, or reset exception occurs. A 
trace exception will occur if the trace state is on when the STOP 
instruction begins execution. If an interrupt request is asserted with a 
priority higher than the priority level set by the immediate data, an 
interrupt exception occurs, otherwise, the interrupt request has no effect. 
If the bit of the immediate data corresponding to the S-bit is off, execution 
of the instruction will cause a privilege violation. External reset will 
always initiate reset exception processing. 


Condition Codes : Set according to the immediate operand. 
Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

E 

□ 

H 


[U 



H 

[±] 


m 


H 

[a] 




Immidiate Data 


Instruction Fields : Immediate field — Specifies the data to be loaded into the status 
register. 
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SUB 


Subtract Binary 


SUB 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination — Source-^Destination 

SUB <ea>,Dn 
SUB Dn, <ea> 

Size = (Byte, Word, Long word) 

Subtract the source operand from the destination operand and store the 
result in the destination. The size of the operation may be specified to be 
byte, word, or long. The mode of the instruction indicates which operand is 
the source and which is the destination as well as the operand size. 


Condition Codes : 

X N Z V C 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflovr is generated. Cleared otherwise. 

C : Set if a borrow is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

The condition codes are not affected if a subtraction from an address register 
is made. 


Instruction Format: 


15 

14 

13 

12 

1110 9 

8 7 6 

5 4 3 2 1 0 

□ 

0 

0 

1 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 


Instruction Fields : 


Register field — Specifies any of the eight data registers. 


Op-Mode field — 

Byte Word Long word 
000 001 010 

100 101 110 


Opration 

<Dn> - <ea>^<Dn> 
<ea> - <Dn> ^<ea> 


Effective Address field — Determines addressing mode: 

If the location specified is a source operand, then all addressing modes are 
allowed as shown: 
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SUB 


SUB 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. NumberiAn 

Abs.W 

111 

000 

Abs. L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 


Addr. Mode 

Mode 

Register 

Dn 

000 


An* 

001 


(An) 

010 


(An) + 

oil 

reg. Number:An 

“(An) 

100 

reg. NumberiAn 

d16(An) 

101 

reg. Number:An 


* : For byte size operaiton, address register direct is not allowed. 

If the location specified is a destination operand, then only alterable memory 
addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

. - 

- 

An 

- 

- 

(An) 

010 

reg. NumberiAn 

(An) + 

oil 

reg. Number;An 

“(An) 

100 

reg. NumberrAn 

die (An) 

101 

reg. NumberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. NumbenAn 

Abs.W 

111 

000 

Abs. L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Notes: 1. If the destination is a data register, then it cannot be specified by using the destination 

<ea> mode, but must use the destination Dn mode instead. 

2. SUB A is used when the destination is an address register. SUBI and SUBQ are used 
when the source is immediate data. Most assemblers automatically make this 
distinction. 
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SUBA 


Subtract Address 


SUBA 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination — Source-^Destination 

SUBA <ea>,An 
Size = (Word, Long word) 

Subtract the source operand from the destination address register and 
store the result in the address register. The size of the operation may be 
specified to be word or long word. Word size source operands are sign 
extended to 32 bit quantities before the operation is done. 


Condition Codes : 
Instruction Format: 


Not affected. 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

u 

0 

0 

0 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Register field — Specifies any of the eight address registers. This is always 
the destination. 

Op-Mode field — Specifies the size of the operation: 

Oil — Word operation. The source operand is sign-extended to a long word 
operand and the operation is performed on the address register using 
all 32 bits. 

Ill— Long word operations. 

Effective Address field — Specifies the source operand. All addressing modes 
are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. NumberiDn 

An 

001 

reg. NumberiAn 

(An) 

010 

reg. Number:An 

(An) + 

Oil 

reg. NumberiAn 

-(An) 

100 

reg. NumberiAn 

d16(An) 

101 

reg. NumberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. NumberiAn 

Abs. W 

111 

000 

Abs. L 

111 

001 

die (PC) 

111 

010 

d8 (PC, Xn) 

111 

oil 

#<data> 

111 

100 
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Subtract Immediate SUBI 

Destination — Immediate Data ^ Destination 

SUBI #<data>, <ea> 

Size = (Byte, Word, Long word) 

Subtract the immediate data from destination operand and store the result 
in the destination location. The size of the operation may be specified to be 
byte, word, or long word. The size of the immediate data matches the 
operation size. 

X N Z V C 
* * * * • * 

N : Set if the result is negative. Cleared otherwise. 

Z ; Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a borrow is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 

0 

0 

0 

0 

0 

1 

_ 

0 

0 

Size 

_ 

Effective Address 
Mode i Register 

Word Data 

Byte Data 

Long Data 


Instruction Fields : 

Size field — Specifies the size of the operation. 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the destination operand. 
Only data alterable addressing modes are allowed as shown: 


SUBI 

Operation 

Assembler 

Syntax 

Attributes 

Description 

Condition Codes 
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SUBI 


SUBI 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. Number:An 

Abs.W 

111 

000 

Abs. L 

111 

001 

die (PC) 


- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. Number:Dn 

An 

- 

- 

(An) 

010 

reg. NumberrAn 

(An) + 

oil 

reg. NumberiAn 

-(An) 

100 

reg. Number:An 

die (An) 

101 

reg. NumbenAn 


Immediate field — (Data immediately following the instruction) 

If size = 00, then the data is the low order byte of the immediate word. 
If size = 01, then the data is the entire immediate w^ord. 

If size = 10, then the data is the next two immediate words. 
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SUBQ 


Subtract Quick 


SUBQ 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Condition Codes 


Destination — Immediate Data —> Destination 


SUBQ 


#<data>, <ea> 


Size = (Byte, Word, Long word) 

Subtract the immediate data from the destination operand. The data 
range is from 1~8. The size of the operation may be specified to be byte, 
word, or long word. Word and long word operations are also allowed on the 
address registers and the condition codes are not affected. When 
subtracting from address registers, the entire destination address register 
is used, regardless of the operation size. 


X N 


V C 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 

C : Set if a borrow is generated. Cleared otherwise. 

X : Set the same as the carry bit. 

The condition codes are not affected if a subtraction from an address register 
is made. 


Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 4 3 2 1 0 


1 

0 

1 

Data 

-I 

Size 

Effective Address 
Mode 1 Register 


Instruction Fields ; 


Data field — Three bits of immediate data, 0, 1~7 representing a range of 8, 
1 to 7 respectively. 

Size field — Specifies the size of the operation. 

00 — byte operation. 

01 — word operation. 

10 — long word operation. 

Effective Address field — Specifies the destination location. Only data 
alterable addressing modes are allowed as shown: 
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SUBQ 


SUBQ 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. Number:Dn 

An* 

001 

reg. NumberiAn 

(An) 

010 

reg. Number:An 

(An) + 

oil 

reg. NumberiAn 

-(An) 

100 

reg. NumberiAn 

d16(An) 

101 

reg. NumberiAn 


Word and long only. 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. NumberiAn 

Abs.W 

111 

000 

Abs. L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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SUBX 


Subtract with Extend 


SUBX 


Operation 

Assembler 

Syntax 

Attributes 

Description 


: Destination — Source — X ^ Destination 

: SUBX Dx, Dy 

SUBX -(Ax),-(Ay) 

: Size = (Byte, Word, Long word) 

: Subtract the source operand from the destination operand along with the 
extend bit and store the result in the destination location. The operands 
may be addressed in two different ways: 

1. Data register to data register: The operands are contained in data 
registers specified in the instruction. 

2. Memory to memory. The operands are contained in memory and 
addressed with the predecrement addressing mode using the address 
registers specified in the instruction. 

The size of the operand may be specified to be byte, word, or long word. 


Condition Codes : 

X N_Z VC 


N : Set if the result is negative. Cleared otherwise. 

Z : Set if the result is zero. Cleared otherwise. 

V : Set if an overflow is generated. Cleared otherwise. 
C : Set if a borrow is generated. Cleared otherwise. 

X : Set the same as the carry bit. 


Note: 


Normally the Z condition code bit is set via programming before the start 
of an operation. This allows successful tests for zero results upon completion 
of multiple-precision operations. 

Instruction Format: 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

P 

0 

3 

1 

Register 

Xv 

1 

Size 

0 

0 

R/M 

Register 

Xx 
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SUBX SUBX 

Instruction Fields : 

Register Xy field — Specifies the destination register: 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement addressing 
mode. 

Size field — Specifies the size of the operation: 

00 — byte operation 
01 — word operation 
10 ~ long operation 

R/M filed — Specifies the operand addressing mode: 

0 — The operation is data register to data register 
1 — The operation is memory to memory 
Register Xx field — Specifies the source register: 

If R/M = 0, specifies a data register. 

If R/M = 1, specifies an address register for the predecrement addressing 
mode. 
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SWAP 

Swap Register Halves 

Deration : 

Register [31:16] Register [15:0] 

Assembler 


Syntax : 

SWAP Dn 

Attributes : 

Size = (Word) 

Descriotion : 

Exchange the 16-bit halves of a data regi 

Condition Codes 



X N Z V C 

- I * I * I 0 I 0 


N : Set if the most significant bit of the 32-bit resultis set. 
Cleared otherwise. 

Z : Set if the 32-bit result is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

1 

0 

0 

0 

0 

0 

0 

0 

1 

0 

0 

0 

Register 


Instruction Fields : 

Register field — Specifies the data register to swap. 


SWAP 
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TAS 


Test and Set an Operand 


TAS 


Destination Tested -> Condition Codes; 1 —^ bit 7 of Destination 

TAS <ea> 

Size = (Byte) 

Test and set the byte operand addressed by the effective address field. The 
current value of the operand is tested and N and Z are set accordingly. The 
high order bit of the operand is set. The operation is indivisible (using a 
read-modify-write memory cycle) to allow synchronisation of several 
processors. 

X N Z V C 

- I * I * I 0 I 0 

N : Set if the most significant bit of the operand was set. 

Cleared otherwise. 

Z : Set if the operand was zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared. 

X : Not affected. 

Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 


□ 

0 

0 

□ 

0 

□ 

0 

1 

1 

Effective Address 
Mode 1 Register 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Condition Codes: 


Instruction Fields : 

Effective Address field — Specifies the location of the tested operand. 
Only data alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. NumberiDn 

An 

- 

- 

(An) 

010 

reg. NumberiAn 

(An) + 

oil 

reg. NumberiAn* 

-(An) 

100 

reg. Number:An 

d16(An) 

101 

reg. NumberiAn 


Addr. Mode 

Mode 

Register 

d8(An, Xn) 

110 

reg. NumberiAn 

Abs. W 

111 

000 

Abs. L 

111 

001 

die (PC) 

- 

- 

d8(PC, Xn) 

- 

- 

#<data > 

- 

- 


Note: Bus error retry is inhibited on the read portion of the TAS read-modify-write bus cycle to 

ensure system integrity. The bus error exception is always taken. 
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TRAP 


Trap 


TRAP 


Operation 


Assembler 

Syntax 

Attributes 

Description 


: SSP — 2 SSP; FormatA^ector Offset (SSP); 

SSP - 4 ^ SSP; PC ^ (SSP); SSP - 2 SSP; 

SR->(SSP); Vector Address-^ PC 

: TRAP #< vector > 

: Unsized 

: The processor initiates exception processing. The vector number is 
generated to reference the TRAP instruction exception vector specified by 
the low order four bits of the instruction. Sixteen TRAP instruction 
vectors (O'^IS) are available. 


Condition Codes ; Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 2 10 

0 

1 

0 

0 

1 

1 

1 

0 

0 

1 

0 

0 

Vector 


Instruction Fields : Vector field — Specifies which trap vector contains the new program 
counter to be loaded. 
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TRAPV 


Trap on Overflow 


TRAPV 


Operation 

Assembler 

Syntax 

Attributes 


: If V then TRAP 

: TRAPV 
: Unsized 


Description : If the overflow condition is set, the processor initiates exception 
processing. The vector number is generated to reference the TRAPV 
exception vector. If the overflow condition is clear, no operation is 
performed and execution continues with the next instruction in sequence. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

s 

1 

0 

0 

□ 

□ 

□ 

0 

0 

1 ’ 

0 

1 

0 

1 

1 

0 
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TST 


Test an Operand 


TST 


Operation 

Assembler 

Syntax 

Attributes 

Description 


Destination Tested Condition Codes 

TST <ea> 

Size = (Byte, Word, Long word) 

Compare the operand with zero. No results are saved; however, the 
condition codes are set according to results of the test. The size of the 
operation maybe specified to be byte, word, or long word. 


Condition Codes : 

X N Z V C 

- I * [ * I 0 [ 0 

N : Set if the operand is negative. Cleared otherwise. 
Z : Set if the operand is zero. Cleared otherwise. 

V : Always cleared. 

C : Always cleared, 

X : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 

0 

1 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 


Instruction Fields : 

Size field — Specifies the size of the operation: 

00 — byte operation 
01 — word operation 
10 — long word operation 

Effective Address field — Specifies the destination operand. Only data 
alterable addressing modes are allowed as shown: 


Addr. Mode 

Mode 

Register 

Dn 

000 

reg. NumbenDn 

An 

. - 

- 

(An) 

010 

reg. NumberiAn 

(An) + 

oil 

reg. Number:An 

-(An) 

100 

reg. NumberrAn 

d16 (An) 

101 

reg. NumberiAn 


Addr. Mode 

Mode 

Register 

d8 (An, Xn) 

110 

reg. NumberiAn 

Abs. W 

111 

000 

Abs. L 

111 

001 

die (PC) 

- 

- 

d8 (PC, Xn) 

- 

- 

#<data> 

- 

- 
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UNLK 


Unlink 


UNLK 


Operation 

Assembler 

Syntax 

Attributes 

Description 


An-^SP; (SP)-^An; SP + 2-^SP 

UNLK An 
Unsized 

The stack pointer is loaded from the specified address register. The 
address register is then loaded with the long word pulled from the top of 
the stack. 


Condition Codes : Not affected. 


Instruction Format: 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

□ 

0 

0 

□ 

1 

□ 

0 

0 

□ 

0 

□ 

□ 

Register 


Instruction Fields : Register field — Specifies the address register through which the 
unlinking is to be done. 
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APPENDIX C INSTRUCTION FORMAT SUMMARY 

C.l INSTRQDUCTION 

This appendix provides a summary of the primary words in each instruction of the 
instruction set. The complete instruction definition consists of the primary words 
followed by the addressing mode operands such as immediate data fields, displacements, 
and index operands. Table C.l is an operand code (opcode) map which illustrates how 
bits 15 -- 12 are used to specify the operations. 


Table C.l 

Operation Code Map 

Bits 15 through 12 

Operation 

0000 

Bit Manipulation / MOVER / Immediate 

0001 

Move Byte 

0010 

Move Long word 

0011 

Move Word 

0100 

Miscellaneous 

0101 

ADDQ/SUBQ/Scc/DBcc 

0110 

Bcc/BSR 

0111 

MOVEQ 

1000 

OR/DIV/SBCD 

1001 

SUB/5UBX 

1010 

(Unassigned, Reserved) 

1011 

CMP/EOR 

1100 . 

AND/MUL/ABCD/EXG 

1101 

ADD/ADDX 

1110 

Shift / Rotate 

1111 

(Unassigned, Reserved) 
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Table C.2. Effective Addressing Mode Categories 


Address Modes 

Mode 

Register 

Data Register Direct 

000 

reg. no. 

Address Register Direct 

001 

reg. no. 

Address Register Indirect 

010 

reg. no. 

Address Register Indirect with Postincrement 

oil 

reg. no. 

Address Register Indirect with Predecrement 

100 

reg. no. 

Address Register Indirect with Displacement 

101 

reg. no. 

Address Register Indirect with Index 

110 

reg. no. 

Absolute Short 

111 

000 

Absolute Long 

111 

001 

Program Counter Indirect with Displacement 

111 

010 

Program Counter Indirect with Index 

111 

oil 

Immediate 

111 

100 


Table C.3. Conditional Tests 


Mnemonic 

Condition 

Encoding 

Test 

T* 

True 

0000 

1 

F* 

False 

0001 

0 

HI 

High 

0010 

c.z 

LS 

Low or Same 

0011 

C + Z 

CC(HS) 

Carry Clear 

0100 

C 

CS (LO) 

Carry Set 

0101 

C 

NE 

Not Equal 

0110 

Z 

EQ 

Equal 

0111 

z 

VC 

Overflow Clear 

1000 

V 

VS 

Overflow Set 

1001 

V 

PL 

Plus 

1010 

N 

Ml 

Minus 

1011 

N 

GE 

Greater or Equal 

1100 

N.V + N.V 

LT 

Less Than 

1101 

N.V+N.V 

GT 

Greater Than 

1110 

N.V.Z + N.V.Z 

LE 

Less or Equal 

1111 

Z + N.V +N.V 


• = Boolean AND + = Boolean OR N= Boolean NOT N 

* : Not available for the Bcc instruction 
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STANDARD INSTRUCTIONS 


ORI 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

0 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 


Size field : 00 = byte 

01 = word 
10 = long word 


ORI to CCR 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 


H 

B 

B 

B 

B 

B 

B 

E 

B 

B 

B 

B 

B 

B 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 


H 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 


Dynamic Bit 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



n 

0 

— 

n 

Data 

1 

Type 

Effective Address 

B 

u 

U 1 
_1 

Register 

Mode 1 Register 


Type field : 00=TST 
01 =CHG 

10 = CLR 

11 = SET 


MOVER 


15 

14 

13 


11 10 9 

8 7 6 

5 

4 

3 

2 1 0 


w 


ilj 

Data 

Register 

OP -Mode 

0 

M 

0 

Address 

Register 


Op-Mode field ; 100 = transfer word from memory to register 

101 = transfer long from memory to register 

110 = transfer word from register to memory 

111 = transfer long from register to memory 
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ANDI 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

0 

0 

0 

0 

0 

1 

0 

Size 

Effective Address 
Mode 1 Register 


Size field : 00 = byte 

01 =word 
10 = long word 


ANDI to CCR 


ANDI to SR 


SUBl 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

E 

0 

0 


0 

0 

0 





0 

0 

R 
















15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 

E 

H 

E 

E 

H 

B 

H 

B 

E 

B 

B 

B 

B 

E 

B 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

0 

0 

0 

0 

0 

1 

0 

0 

Size 

Effective Address 
Mode I Register 


Size field : 00 = byte 

01 =word 
10 = long word 


ADD! 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 

0 

0 

0 

0 

0 

1 

0 

0 

Size 

Effective Address 
Mode 1 Register 


Size field : 00 = byte 

01 = word 
10 = long word 
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Static Bit 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Type field : 00=TST 
01 =CHG 

10 = CLR 

11 = SET 


EORI 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 =word 
10 = long word 


EORI to CCR 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



EORI to SR 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



CMPI 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 =word 
10 = long word 
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MOVES 


15 

14 

13 

12 

11 

10 

9 

8 

7 6 

5 4 3 2 1 0 

M 

M 

M 

0 

M 

□ 

M 

M 

Size 

Effective Address 
Mode 1 Register 


Size field : 00 = byte 

01 =word 
10 = long word 


MOVE (Byte) 


15 

14 

13 

12 

11 10 9 8 7 6 

5 4 3 2 1 0 

M 

0 

M 

N 

Destination 
Register | Mode 

Source 

Mode 1 Register 


Note register and mode locations 


MOVEA (Long word) 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 


0 

□ 

M 

Address 

Register 

M 


□ 

Source 

Mode 1 Register 


MOVE (Long word) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 


1 


Destination 

Source 


LiJ 

rj 

Register | Mode 

Mode 1 Register 


Note register and mode locations 


MOVEA (Word) 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

M 

M 

□ 

N 

Address 

Register 

H 

0 

N 

Source 

Mode 1 Register 
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MOVE (Word) 



14 

13 

12 

11 10 9 8 7 6 

5 4 3 2 1 0 

ilj 

0 

□ 

1 

Destination 
Register | Mode 

Source 

Mode 1 Register 


Note register and mode locations 


NEGX 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



□ 

0 

0 

0 

0 

0 

0 

Size 

Effective Address 
Mode 1 Register 


Size field : 00 = byte 

01 =word 
10 = long word 


MOVE from SR 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

□ 

0 

0 

0 

0 

0 

0 

0 

0 

Effective Address 
Mode 1 Register 


CHK 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

M 

0 

M 

M 

Data 

Register 

0 

M 

0 

Effective Address 
Mode 1 Register 


LEA 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 2 1 0 

M 

M 

M 

M 

Address 

Register 

0 

0 

1 

Effective Address 
Mode 1 Register 
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CLR 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 =word 
10 = long word 


MOVE from CCR 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



NEG 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 = word 
10 = long word 


MOVE to CCR 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



NOT 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 =word 
10 = long word 
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MOVE to SR 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

M 

1 

0 

M 

ll 

□ 

□ 

M 

1 

E 

Effective Address 
Mode 1 Register 


NBCD 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


B 

1 

0 

0 

□ 

0 

0 

0 

0 

0 

Effective Address 
Mode 1 Register 


SWAP 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

M 

1 

0 

0 

1 

0 

0 

M 

0 

1 

H 

0 

M 

Data 

Register 


BKPT 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

A 

□ 

0 


1 

A 


0 

0 

□ 

A 

A 

□ 

BKPT# 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

1 

0 

0 

1 

0 

0 

□ 

0 

1 

Effective Address 
Mode 1 Register 


EXT 


15 

14 

13 

12 

11 

10 

9 

8 7 6 

5 

4 

3 

2 1 0 

0 

□ 

0 

0 

0 ] 

0 

0 

Op-Mode 

0 

0 

0 

Data 

Register 


Op-Mode field : 010 = Extend Word 

011= Extend Long word 
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MOVEM (Registers to EA) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Sz field : 0 = word transfer 

1 = long word transfer 


TST 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Size field : 00 = byte 

01 = word 
10 = long word 


TAS 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



ILLEGAL 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



MOVEM (EAto Registers) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Sz field : 0 = word transfer 

1 = long word transfer 
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TRAP 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

1 


0 

1 



0 

0 


0 

0 

Vector 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

0 

0 

0 

□ 

1 

1 

0 

0 

□ 

0 

1 1 

0 

Address 

Register 


UNLK 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

1 

0 

0 

1 

1 

_ 1 

1 

1 

0 

0 

1 

0 

1 

1 

Address 

Register 


MOVEtoUSP 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

1 

0 

0 

1 

1 

1 

0 

0 

1 

1 

0 

0 

Address 

Register 


MOVE from USP 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 1 0 

0 

1 

0 

0 

1 

1 

□ 

0 

0 

1 

1 

0 

1 

Address 

Register 


RESET 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

E 

B 

B 

B 

E 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 
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NOP 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 

H 

H 

H 


H 

H 

B 

B 

B 

B 

B 

B 

B 

B 

B 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

H 


E 

H 



E 

B 

B 

B 

B 

B 

B 

B 

B 

B 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 


RTD 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 


TRAPV 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 

B 
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RTR 


MOVEC 


JSR 


JMP 


ADDQ 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

E 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 


0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

dr 


drfield 0 = control register to general register 
1 = general register to control register 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

□ 

0 

0 

1 

1 

□ 

0 

□ 

0 

Effective Address 
Mode 1 Register 


15 

14 

13 

12 

11 

10 

9 

8 

7 

6 

5 4 3 2 1 0 

M 

0 

M 

0 

1 

M 

0 

M 

M 

N 

Effective Address 
Mode 1 Register 




13 

12 

11 10 9 

8 

7 6 

5 4 3 2 1 0 

ilj 

ih 

M 

0 

Data 

M 

Size 

Effective Address 
Mode 1 Register 


Data field Three bits of immediate data, 0, 1~7 representing a range 
of 8, 1 to 7 respectively. 

Size field : 00 = byte 

01 = word 
10 = long word 
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See 


15 

14 

13 

12 

11 10 9 8 

7 

6 

5 4 3 2 1 0 

M 

□ 

M 

□ 

Condition 

□ 

□ 

Effective Address 
Mode 1 Register 


Condition field : 

0000 = always true 
0001 = nevertrue 
0010 = high 
0011 = low or same 
0100 = carry clear 
0101 = carry set 
0110 = not equal 
0111=equal 


1000 = overflow clear 

1001 = overflow set 

1010 = plus 

1011 = minus 

1100 = greater or equal 

1101 =lessthan 

1110 = greater than 

1111 = lessor equal 


DBcc 


15 

14 

13 

12 

11 10 9 8 

7 

6 

5 

4 

3 

2 1 0 

M 

M 

0 

□ 

Condition 

□ 

1 

0 

M 

□ 

Data 

Register 


Condition field : 

0000 = always true 
0001 = nevertrue 
0010 = high 
0011 = low or same 
0100 = carry clear 
0101 = carry set 
0110 = not equal 
0111= equal 


1000 = overflow clear 

1001 = overflow set 

1010 = plus 

1011 = minus 

1100 = greater or equal 

1101 = less than 
1110 = greater than 
1111= less or equal 
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SUBQ 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 4 3 2 1 0 

M 

□ 

0 

M 

Data 

□ 

Size 

Effective Addess 
Mode 1 Register 


Data field Three bits of immediate data, 0, 1~7representing a range 
of 8, 1 to 7 respectively. 

Size field . 00 = byte 

01 = word 
10 = long word 


Bcc 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


0 

Zl 

Z] 

H 

Condition 

8-Bit Displacement 


Condition field : 


0010 = high 
0011 = low or same 
0100 = carry clear 
0101 = carry set 
0110 = not equal 
0111= equal 


1000 = overflow clear 

1001 = overflow set 
1010 = plus 
1011= minus 

1100 = greater or equal 

1101 = less than 
1110 = greaterthan 
1111= less or equal 


BRA 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


H 

Z] 

[Z 

H 

z: 


H 

H 

8-Bit Displacement 


BSR 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



1 

1 


0 

0 


_L 

8-Bit Displacement 
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MOVEQ 


OR 


DIVU 


SBCD 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 

2 1 0 


1 

1 

1 

Data 

Register 

0 

Data 

Data field 

Data is sign extended to a long word operand and all 
are transferred to the data register. 

15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 

2 1 0 

1 

0 

0 

0 

Data 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

byte Word Long word 

000 001 010 

100 101 110 

<ea> 

<Dn> 

Operation 

V <Dn> 

V <ea> 

^ <Dn> 
-> <ea> 

15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 4 3 

2 1 0 

r 

0 



Data 

Register 

0 

□ 

1 

Effective Address 
Mode 1 Register 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 

□ 

0 

w 

0 

Destination 

Register* 

□ 

0 

0 

0 

0 

R/M 

Source 

Register* 


R/M field 0 = data register to data register 
1 = memory to memory 
* If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode. 
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DIVS 


SUB 


SUBA 


SUBX 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 





Data 

Register 




Effective Address 
Mode 1 Register 

15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 


0 

0 

1 

Data 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

Byte Word Long word 

000 001 010 

100 101 110 

Operation 

(<Dn>)-(<ea>) <Dn> 
(<ea>)-(<Dn>) -» <ea> 

15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 


0 

0 

1 

Address 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

Word Long word 

000 111 

Operation 

(<ea>)-(<An>)-^<An> 

15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 10 





Destination 

Register* 

3 

Size 



R/M 

Source 

Register* 


Size field 00 = byte 

01 =word 
10 = long word 

R/M field : 0 = data register to data register 

1 = memory to memory 
* : If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode. 
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CMP 


CMPA 


EOR 


CMPM 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

■ 

0 

1 

1 

Data 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

Byte Word Long word 

000 001 010 

Operation 

(<Dn>H<ea>) 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

1 

0 

1 

1 

Address 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

Word Long word 

oil 001 

Operation 

(<An>)-(<ea>) 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 


0 

1 

1 

Data 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 

Op-Mode field: 

Byte Word Long word 

100 101 110 

Operation 

(<ea>)©{<Dn >) -^ <ea> 

15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

3 

lIj 

rr 

1 

Destination 

Register 

’ 

Size 




Source 

Register 


Size field : 00 = byte 

01 = word 
10 = long word 
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AND 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Op-Mode field; 

Byte Word Long word Operation 

000 001 010 (<ea>)A(<Dn>)-»<Dn> 

100 101 110 (<Dn>)A(<ea>) ^ <ea> 


MULU 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



ABCD 


15 

14 13 

12 

11 10 9 

8 


6 

5 

4 3 2 1 0 

□ 

1 0 


Destination 

Register* 


lij 

0 


0 R/M Source 

Register* 


R/M field 0 = data register to data register 
1 = memory to memory 
* If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode. 


EXG (Data Registers) 


15 14- 13 12 

1110 9 

8 

7 

6 

5 

4 

3 

2 1 0 

110 0 

Data 

Register 

1 

u 

□ 

0 

0 

0 

Data 

Register 

EXG (Address Registers) 









15 14 13 12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 

110 0 

Address 

Register 

1 

0 

□ 

0 

0 

□ 

Address 

Register 
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EXG (Data Register and Address Register) 


15 

14 

13 

12 

11 10 9 

8 

7 

6 

5 

4 

3 

2 1 0 

□ 

1 

0 

0 

Data 

Register 

□ 

E 

0 

0 

0 

0 

Address 

Register 


MULS 


ADDA 


15 14 13 12 11 10 9 8 



1 

□ 

0 

B 

ADD 






15 

14 

13 

12 


1 

□ 

0 

□ 


Data 

Register 


Effective Address 
Mode I Register 


Data 

Register 


Op-Mode 


Effective Address 
Mode I Register 


OP-Mode field: 

Byte Word Long word Operation 

000 001 010 (<ea>)+ (<Dn>)-><Dn> 

100 101 110 (<Dn>)+ (<ea>)-> <ea> 


15 

14 

13 

12 

11 10 9 

8 7 6 

5 4 3 2 1 0 

0 

□ 

0 

□ 

Address 

Register 

Op-Mode 

Effective Address 
Mode 1 Register 


OP-Mode field: 

Word Long word Operation 

oil 111 (<ea>)+ (<An>)<An> 


ADDX 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 

3 

2 1 0 

□ 

1 

0 

1 

Destination 

Register* 

□ 

Size 

0 

0 

R/M 

Source 

Register* 


Size field : 00 = byte 

01 =word 
10 = long word 

R/M field : 0 = data register to data register 

1 = memory to memory 
* : If R/M = 0, specifies a data register 

If R/M = 1, specifies an address register for the predecrement addressing mode. 
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SHIFT/ROTATE (Register) 


15 

14 

13 

12 

11 10 9 

8 

7 6 

5 

4 3 

2 1 0 

□ 

□ 

□ 

0 

Count/ 

Register 

0 

Size 

0 

Type 

Data 

Register 


Count/Register field : 


dr field : 0 = right 
1=left 


If i/r field = 0, specifies shift count 

If l/r field = 1, specifies a data register that contains the shift 
count 


Size field : 00 = byte 
01 =word 
10 = long word 

i/r field : 0 = immediate shift count 

I = register shift count 
Type field : 00 = arithmetic shft 

01 = logical shift 
10 = rotate with extend 

II = rotate 


SHIFT/ROTATE (Memory) 


15 

14 

13 

12 

11 

10 9 

8 

7 

6 

5 4 3 2 1 0 

0 

□ 

□ 

0 

0 

Type 

0 

□ 

0 

Effective Address 
Mode 1 Register 


Type field : 00 = arithmetic shift 
01 = logical shift 

10 = rotate with extend 

11 = rotate 

dr field : 0 = right 
1 = left 
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APPENDIX D TMP68Q00 INSTRUCTION EXECUTION TIMES 

D.l INTRODUCTION 

This Appendix contains listings of the instruction execution times in terms of 
external clock (CLK) periods. In this data, it is assumed that both memory read and 
write cycle times are four clock periods. A longer memory cycle will cause the 
generation of wait states which must be added to the total instruction time. 

The number of bus read and write cycles for each instruction is also included with the 
timing data. This data is enclosed in parenthesis following the number of clock periods 
and is shown as: (r/w) where r is the number of read cycles and w is the number of write 
cycles included in the clock period number. Recalling that either a read or write cycle 
requires four clock periods, a timing number given as 18(3/1) relates to 12 clock periods 
for the three read cycles, plus 4 clock periods for the one write cycle, plus 2 cycles 
required for some internal function of the processor. 

Note: 

The number of periods includes instruction fetch and all applicable operand fetches 
and stores. 

D.2 OPERAND EFFECTIVE ADDRESS CALCULATION TIMES 

Table D.l lists the number of clock periods required to compute an instruction’s 
effective address. It includes fetching of any extension words, the address computation, 
and fetching of the memory operand. The number of bus read and write cycles is shown 
in parenthesis as (r/w). Note there are no write cycles involved in processing the 
effective address. 
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Table D.l Effective Address Calculation Times 



Addressing Mode 

Byte, Word 

Long word 

Dn 

Register 

Data Register Direct 

0 (0/0) 

0 (0/0) 

An 

Address Register Direct 

0 (0/0) 

0 (0/0) 

(An) 

Memory 

Address Register Indirect 

4 (1/0) 

8 (2/0) 

(An) + 

Address Register Indirect with Postincrement 

4 (1/0) 

8 (2/0) 

-(An) 

Address Register Indirect with Predecrement 

6 (1/0) 

10 (2/0) 

d16(An) 

Address Register Indirect with Displacement 

8 (2/0) 

12 (3/0) 

d8(An, Xn)* 

Address Register Indirect with Index 

10 (2/0) 

14 (3/0) 

Abs.W 

Absolute Short 

8 (2/0) 

12 (3/0) 

Abs. L 

Absolute Long 

12 (3/0) 

16 (4/0) 

die (PC) 

Program Counter with Displacement 

8 (2/0) 

12 (3/0) 

die (PC, Xn)* 

Program Counter with Index 

10 (2/0) 

14 (3/0) 

#<data> 

Immediate 

4 (1 /O) 

8 (2/0) 


The size of the index register (Xn) does not affect execution time. 


D.3 MOVE INSTRUCTION EXECUTION TIMES 


Table D.2 and D.3 indicate the number of clock periods for the move instruction. This 
data includes instruction fetch, operand reads, and operand writes. The number of bus 
read and write cycles is shown in parenthesis as (r/w). 
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Table D.2 Move Byte and Word Instruction Execution Times 


Source 

Destination 

Dn 

An 

(An) 

(An) + 

-(An) 

dl6(An) 

d8(An,Xn)* 

Abs. W 

Abs. L 

Dn 

4(1/0) 

4(1/0) 

8(1/1) 

8(1/1) 

8(1/1) 

12 (2/1) 

14(2/1) 

12(2/1) 

16(1/3) 

An 

4(1/0) 

4(1/0) 

8(1/1) 

8(1/1) 

8(1/1) 

12(2/1) 

14(2/1) 

12(2/1) 

16(1/3) 

(An) 

8(2/0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16 (3/1) 

18(3/1) 

16(3/1) 

20(4/1) 

(An) + 

8(2/0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16(3/1) 

18(3/1) 

16(3/1) 

20(4/1) 

-(An) 

10(2/0) 

10(2/0) 

14(2/1) 

14(2/1) 

14(2/1) 

18(3/1) 

20(3/1) 

18(3/1) 

22(1 /4) 

dl6(An) 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

20 (4/1) 

22 (4/1) 

20(4/1) 

24(5/1) 

d8(An, Xn)* 

14(3/0) 

14(3/0) 

18(3/1) 

18(3/1) 

18(3/1) 

22 (4/1) 

24(4/1) 

22 (4/1) 

26(5/1) 

Abs. W 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/ 1) 

20 (4/1) 

22(4/1) 

20 (4/1) 

24(5/1) 

Abs. L 

16 (4 / 0) 

16(4/0) 

20(4/1) 

20 (4/1) 

20(4/1) 

24 (5/1) 

26(5/1) 

24(5/1) 

28(6/1) 

d16(PC) 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/ 1) 

16(3/1) 

20 (4/1) 

22(4/ 1) 

20 (4/ 1) 

24(5/1) 

d8(PC, Xn)* 

14(3/0) 

14(3/0) 

18(3/1) 

18(3/1) 

18(3/ 1) 

22 (4/1) 

24(4/1) 

22(4/ 1) 

26(5/1) 

#<data> 

8 (2 / 0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16 (3/ 1) 

18(3/1) 

16(3/1) 

20(4/ 1) 


The size of the index register (Xn) does not affect execution time. 


Table D.3 Move Long Word Instruction Execution Times 


Source 

Destination 

Dn 

An 

(An) 

(An) + 

-(An) 

d 16 (An) 

d8(An,Xn)* 

Abs. W 

Abs. L 

Dn 

4(1/0) 

4(1/0) 

■ 

12(1/2) 

12(1/2) 

12(1/2) 

16(2/2) 

18(2/2) 

16(2/2) 

20(3/2) 

An 

4(1/0) 

4(1/0) 

12(1/2) 

12(1/2) 

12(1/2) 

16(2/2) 

18(2/2) 

16(2/2) 

20(3/2) 

(An) 

12(3/0) 

12 (3/0) 

20(3/2) 

20(3/2) 

20 (3/2) 

24(4/2) 

26(4/2) 

24 (4/2) 

28(5/2) 

(An) + 

12(3/0) 

12(3/0) 

20(3/2) 

20(3/2) 

20(3/2) 

24(4/2) 

26(4/2) 

24 (4/2) 

28(5/2) 

-(An) 

14(3/0) 

14(3/0) 

22(3/2) 

22 (3 / 2) 

22 (3 / 2) 

26(4/2) 

28(4/2) 

26(4/2) 

30(5/2) 

d16(An) 

16(4/0) 

16(4/0) 

24(4/2) 

24 (4 / 2) 

24 (4/2) 

28(5/2) 

30(5/2) 

28(5/2) 

32(6/2) 

d8(An, Xn)* 

18(4/0) 

18(4/0) 

26(4/2) 

26 (4/2) 

26 (4/2) 

30(5/2) 

32(5/2) 

30(5/2) 

34(6/2) 

Abs. W 

16(4/0) 

16(4/0) 

24(4/2) 

24 (4/2) 

24 (4/2) 

28(5/2) 

30(5/2) 

28(5/2) 

32(6/2) 

Abs. L 

20(5/0) 

20(5/0) 

28(5/2) 

28 (5/2) 

28(5/2) 

32(6/2) 

34(6/2) 

32(6/2) 

36(7/2) 

die (PC) 

16(4/0) 

16(4/0) 

24(4/2) 

24 (4/2) 

24 (4/2) 

28(5/2) 

30(5/2) 

28(5/2) 

32(5/2) 

d8(PC, Xn)* 

18(4/0) 

18(4/0) 

26(4/2) 

26(4/2) 

26(4/2) 

30(5/2) 

32(5/2) 

30(5/2) 

34(6/2) 

#<data> 

12(3/0) 

12(3/0) 

20(3/2) 

20(3/2) 

20(3/2) 

24 (4/2) 

26(4/2) 

24 (4/2) 

28(5/2) 


The size of the index register (Xn) does not affect execution time. 
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D.4 STANDARD INSTRUCTION EXECUTION TIMES 


The number of clock periods shown in Table D.4 indicates the time required to 
perform the operations, store the results, and read the next instruction. The number of 
bus read and write cycles is shown in parenthesis as (r/w). The number of clock periods 
and the number of read and write cycles must be added respectively to those of the 
effective address calculation where indicated. 

In Table D.4 the headings have the following meanings: An = address register 
operand, Dn = data register operand, ea = an operand specified by an effective address, 
and M = memory effective address operand. 


Table D.4 Standard Instruction Execution Times 


Instruction 

Size 

op<ea>. An 

op<ea>. 

Dn 

op Dn, <M> 

ADD/ADDA 

Byte, Word 

6(1/0) +** 

4(1 /O) 

+ 

8(1/1) + 

Long word 

8(1 /O) + 

6(1 /O) 

^ ** 

12(1/2) + 

AND 

Byte, Word 

— 

4(1 /O) 

+ 

8(1/1) + 

Long word 

- 

6(1/0) 

^ ** 

12(1/2) + 

CMP/CMPA 

Byte, word 

6(1/0) + 

4(1/0) 

+ 

- 

Long word 

6(1/0) + 

6(1/0) 

+ 

- 

DIVS 

- 

— 

158(1 /O) 

+ * 

- 

DIVU 

- 

— 

140(1 /O) 

* 

- 

EOR 

Byte, Word 


4(1/0) 

*** 

8(1/1) + 

Long word 

— 

8(1/0) 

*** 

12(1/2) + 

MULS 

- 

— 

70(1 /O) 

+ * 


MULU 

- 

— 

70(1 /O) 

+ * 

- 

OR 

Byte, Word 

— 

4(1/0) 

+ 

8(1 /I) + 

Long word 

— 

6(1 /O) 

_i_ ** 

12(1/2) + 

SUB 

Byte, Word 

8(1/0) + 

4(1/0) 

+ 

8(1/1) + 

Lonq word 

6(1/0)+** 

6(1/0) 

^ ** 

12(1 12) + 


Note : 

+ : add effective address calculation time 

A : word or long word only 

* : indicates maximum basic value added to word effective address time. 

* * : The base time of six clock periods is increased to eight if the effective address mode is 

register direct or immediate (effective address time should also be added). 

*** : Only available effective address mode is data register direct. 

DIVS, DIVU - The divide algorithm used by the TMP68000 provides less than 10% difference 
between the best and worst case timings. 

MULS, MULU - The multiply algorithm requires 38 + 2n clocks where n is defines as: 

MULS: n = the number of ones in the <ea> 

MULU: n= concatanate the <ea>with a zero as the LSB;n is the resultant number of 10 
or 01 patterns in the 17-bit source; i.e., worst case happens when the source is 
$5555. 


VMPU-230 












TOSHIBA 


TLCS-68000 


D.5 IMMEDIATE INSTRUCTION EXECUTION TIMES 


The number of clock periods shown in Table D.5 includes the time to fetch immediate 
operands, perform the operations, store the results, and read the next operation. The 
number of bus read and write cycles is shown in parenthesis as (r/w). The number of 
clock periods and number of read and write cycles must be added respectively to those of 
the effective address calculation where indicated. 

In Table D.5, the headings have the following meanings: 

# = immediate operand, 

Dn = data register operand. 

An = address register operand, 

M = memory operand. 

SR = status register. 


Table D.5 Immediate Instruction Execution Times 


Instruction 

Size 

op #, Dn 

op #, An 

op #, M 

ADDI 

Byte, Word 

8 (2 / 0) 

- 

12(2/1) + 

Long word 

16(3/0) 

- 

20(3/2) + 

ADDQ 

Byte, Word 

4(1/0) 

8(1/0)* 

8(1 /I) + 

Long word 

8(1 /O) 

8(1/0) 

12(1/2) + 

ANDI 

Byte, Word 

8(2/0) 

- 

12(2/1) + 

Long word 

16(3/0) 

- 

20(3/1) + 

CMPl 

Byte, Word 

8(2/0) 

— 

8(2/0) + 

Long word 

14(3/0) 

- 

12(3/0) + 

EORI 

Byte, Word 

8(2/0) 

— 

12(2/1) + 

Long word 

16(3/0) 

- 

20(3/2) + 

MOVEQ 

Long word 

4(1/0) 

- 

- 

ORI 

Byte, Word 

8(2/0) 

- 

12(2/1) + 

Long word 

16(3/0) 

- 

20(3/2) + 

SUBI 

Byte, Word 

8(2/0) 

- 

12(2/1) 

Long word 

16(3/0) 

- 

20(3/2) + 

SUBQ 

Byte, Word 

4(1/0) 

8(1/0)* 

8(1/1) + 

Long word 

8(1/0) 

8(1 /O) 

12(1/2) + 


-f ; add effective address calculation time 
* : word only 


D.6 SINGLE OPERAND INSTRUCTION EXECUTION TIMES 


Table D.6 indicates the number of clock periods for the single operand instructions. 
The number of bus read and write cycles is shown in parenthesis as (r/w). The number of 
clock periods and the number of read and write cycles must be added respectively to 
those of the effective address calculation where indicated. 
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Table D.6 Single Operand Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

CLR 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1 /O) 

12(1/2) + 

NBCD 

Byte 

6(1/0) 

8(1/1) + 

NEG 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1/0) 

12(1 12) + 

NEGX. 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1/0) 

12(1/2) + 

NOT 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1/0) 

12(1/2) + 

See 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1/0) 

8(1/1) + 

TAS 

Byte 

4(1/0) 

10(1/1) + 

TST 

Byte, Word 

4(1 /O) 

4(1/0) + 

Long word 

4(1 /O) 

4(1/0) + 


+ : add effective address calculation time 

D.7 SHIFT/ROTATE INSTRUCTION EXECUTION TIMES 


Table D.7 indicates the number of clock periods for the shift and rotate instructions. 
The number of bus read and write cycles is shown in parenthesis as (r/w). The number of 
clock periods and the number of read and write cycles must be added respectively to 
those of the effective address calculation where indicated. 


Table D.7 Shift/Rotate Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

ASR, ASL 

Byte, Word 

6 + 2n(1/0) 

8(1/1) + 

Long word 

8 + 2n(1 /O) 

- 

L5R, LSL 

Byte, Word 

6 + 2n(1/0) 

8(1/1) + 

Long word 

8 + 2n (1 /O) 

- 

ROR, ROL 

Byte, Word 

6 + 2n (1 /O) 

8(1/1) + 

Long word 

8 + 2n(1/0) 


ROXR, ROXL 

Byte, Word 

6 + 2n(1/0) 

8(1/1) + 

Long word 

8 + 2n(1/0) 

- 


+ : add effective address calculation time for word operands 
n : the shift count 
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D.8 BIT MANIPULATION INSTRUCTION EXECUTION TIMES 


Table D.8 indicates the number of clock periods required for the bit manipulation 
instructions. The number of bus read and write cycles is shown in parenthesis as (r/w). 
The number of clock periods and the number of read and write cycles must be added 
respectively to those of the effective address calculation where indicated. 


Table D.8 Bit Manipulation Instruction Execution Times 


Instruction 

Size 

Dynamic 

Static 

Register 

Memory 

Register 

Memory 

BCHG 

Byte 

— 

8(1/1) + 

— 

12(2/1) + 

Long word 

8(1/0)* 

- 

12(2/0) 

- 

BCLR 

Byte 

- 

8(1/1) + 

- 

12(2/1) + 

Long word 

10(1 /O) 

— 

14(2/0)* 

- 

BSET 

Byte 

— 

8(1/1) + 

— 

12(2/1) + 

Long word 

8(1/0)* 

- 

12(2/0)* 

- 

BIST 

Byte 

- 

4(1/0) + 

— 

8(2/0) + 

Long word 

6(1/0) 

- 

10(2/0) 

- 


+ : add effective address calculation time 


* : indicates maximum value; data addressing mode only 


D.9 CONDITIONAL INSTRUCTION EXECUTION TIMES 


Table D.9 indicates the number of clock periods required for the conditional 
instructions. The number of bus read and write cycles is indicated in parenthesis as 
(r/w). The number of clock periods and the number of read and write cycles must be 
added respectively to those of the effective address calculation where indicated. 


Table D.9 Conditional Instruction Execution Times 


Instruction 

Displacement 

Branch Taken 

Branch NotTaken 

Bcc 

Byte 

10(2/0) 

8(1 /O) 

Word 

10(2/0) 

12(2/0) 

BRA 

Byte 

10(2/0) 

- 

Word 

10(2/0) 

_ 

BSR 

Byte 

18(2/2) 

- 

Word 

18(2/2) 

- 

DBcc 

cctrue 

- 

12(2/0) 

cc false, Count Not Expired 

10(2/0) 

- 

cc false, Count Expired 

- 

14(3/0) 


+ : add effective address calculation time 


indicates maximum base value 
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D.IO JMP, JSR, LEA, PEA, AND MOVEM INSTRUCTION EXECUTIONTIMES 

Table D.IO indicates the number of clock periods required for the jump, jump-to- 
subroutine, load effective address, push effective address, and move multiple registers 
instructions. The number of bus read and write cycles is shown in parenthesis as (r/w). 


Table D.IO JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times 


In-struc- 

tion 

Size 

(An) 

(An) + 

-(An) 

d 16 (An) 

d8(An,Xn)* 

Abs. W 

Abs. L 

d16(PC) 

d8 (Pc, Xn)* 

JMP 

- 

8 (2/0) 

- 

- 

10(2/0) 

14(3/0) 

10 (2/0) 

12 (3/0) 

10 (2/0) 

14(3/0) 

JSR 

- 

16 (2/2) 

- 

- 

18(2/2) 

22(2/2) 

18 (2/2) 

20 (3/2) 

18 (2/2) 

22(2/2) 

LEA 

- 

4 (1/0) 

- 

- 

8(2/0) 

12(2/0) 

8 (2/0) 

12 (3/0) 

8 (2/0) 

12(2/0) 

PEA 

- 

12 (1/2) 

_ 

- 

16(2/2) 

20 (2/2) 

16 (2/2) 

20 (3/2) 

16 (2/2) 

20(2/2) 


Word 

12 + 4n 

12 + 4n 

- 

16 + 4n 

18 + 4n 

16 + 4n 

20 + 4n 

16 + 4n 

18 + 4n 

MOVEM 


(3 + n / 0) 

(3 + n/O) 


(4 + n / 0) 

(4-t-n/O) 

(4 + n / 0) 

(5 + n/O) 

(4 + n / 0) 

(4 + n / 0) 

M-^R 

Long 

12 + 8n 

12 + 8n 

- 

16 + 8n 

18 + 8n 

16 +8n 

20 + 8n 

16 + 8n 

c 

00 

+ 

00 


i 

(3 + 2n/0) 

(3 + 2n/0) 


(4 + 2n/0) 

(4 + 2n/0) 

(4 + 2n/0) 

(5 + 2n/0) 

(4 + 2n / 0) 

(4 + 2n/0) 


Word 

8 + 4n 

- 

8 + 4n 

12-f4n 

14-»-4n 

12 + 4n 

16 + 4n 

- 

- 

MOVEM 


(2/n) 


(2/n) 

(3/n) 

(3/n) 

(3/n) 

(4/n) 

- 

- 

R^M 

Long 

8 + 8n 

- 

8 + 8n 

12 + 8n 

14 + 8n 

12 + 8n 

16 + 8n 

- 

- 



(2/2n) 

- 

(2/2n) 

(3/2n) 

(3/2n) 

(3/2n) 

(4/2n) 

- 

- 


n : the number of registers to move 

* : the size of the index register (Xn) does not affect the instruction’s execution time 


D.ll MULTI-PRECISION INSTRUCTION EXECUTION TIMES 


Table D.ll indicates the number of clock periods for the multi-precision instructions. 
The number of clock periods includes the time to fetch both operands, perform the 
operations, store the results, and read the next instructions. The number of bus read 
and write cycles is shown in parenthesis as (r/w). 

In Table D.ll, the headings have the following meaning: Dn = data register 
operand and M = memory operand. 


Table D.ll Multi-Precision Instruction Execution Times 


Instruction 

Size 

op Dn, Dn 

op M, M 

ADDX 

Byte, Word 

4(1/0) 

18(3/1) 

Long word 

8(1 /O) 

30(5/2) 

CMPM 

Byte, Word 

— 

12(3/0) 

Long word 

— 

20(5/0) 

SUBX 

Byte, Word 

4(1/0) 

18(3/1) 

Long word 

8(1/0) 

30(5/2) 

ABCD 

Byte 

6(1 /O) 

18(3/1) 

SBCD 

Byte 

6(1 /O) 

18(3/1) 
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D.12 MISCELLANEOUS INSTRUCTION EXECUTION TIMES 

Table D.12 and D.13 indicate the number of clock periods for the folowing 
miscellaneous instructions. The number of bus read and write cycles is shown in 
parenthesis as (r/w). The number of clock periods plus the number of read and write 
cycles must be added to those of the effective address calculation where indicated. 


Table D.12 Miscellaneous Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

ANDI to CCR 

Byte 

20 (3/0) 

- 

ANDI to SR 

Word 

20(3/0) 

- 

CHK(No Trap) 

- 

10(1/0) + 

- 

EORI to CCR 

Byte 

20(3/0) 

- 

EORI to SR 

Word 

20(3/0) 

- 

ORI to CCR 

Byte 

20(3/0) 

- 

ORI to SR 

Word 

20(3/0) 

- 

MOVE from SR 

- 

6(1 /O) 

8(1/1) + 

MOVE to CCR 

- 

12(1/0) 

12(2/0) + 

MOVE to SR 

- 

12(1/0) 

12(2/0) + 

EXG 

- 

6(1/0) 

- 

EXT 

Word 

4(1/0) 

- 

Long word 

4(1/0) 

- 

LINK 

- 

16(2/2) 

- 

MOVE from USP 

- 

4(1 /O) 

- 

MOVE to USP 

- 

4(1 /O) 

- 

NOP 

- 

4(1 /O) 

- 

RESET 

- 

132(1/0) 


RTE 

- 

20(5/0) 

- 

RTR 

_ 

20 (5 / 0) 

- 

RTS 

- 

16(4/0) 

- 

STOP 

_ 

4(0/0) 

- 

SWAP 

- 

4(1/0) 

- 

TRAPV 

- 

4(1/0) 

- 

UNLK 

- 

12(3/0) 

- 


+ : add effective address calculation time 


Table D.13 Move Peripheral Instruction Execution Times 


Instruction 

Size 

Register -> Memory 

Memory—^Register 


Word 

16(2/2) 

16(4/0) 

MOVEP 

Long word 

24(2/4) 

24(6/0) 
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D.13 EXCEPTION PROCESSING EXECUTION TIMES 

Table D.14 indicates the number of clock periods for exception processing. The 
number of clock periods includes the time for all stacking, the vector fetch, and the fetch 
of the first two instruction words of the handler routine. The number of bus read and 
write cycles is shown in parenthesis as (r/w). 


Table D.14 Exception Processing Execution Times 


Exception 

Periods 

Address Error 

50 (4/7) 

Bus Error 

50(4/7) 

CHK Instruction 

44(5/4) + 

Divide by Zero 

42(5/4) 

llegal Instruction 

34(4/3) 

Interrupt 

44(5/3)* 

Privilege Violation 

34 (4/3) 

RESET** 

40 (6/0) 

Trace 

34(4/3) 

TRAP Instruction 

38(4/4) 

TRAPV Instruction 

34(4/3) 


+ : add effective address calculation time 

* : The interrupt acknowledge cycle is assumed to take four clock periods. 

** : Indicates the time from when RESET and HALT are first sampled as negated 

to when instruction execution satrts. 
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APPENDIX E TMP68008 INSTRUCTION EXECUTION TIMES ! 

- I 

E.l INTRODUCTION I 

This Appendix contains listings of the instruction execution times in terms of n 
external clock (CLK) periods. In this data, it is assumed that both memory read and n 
write cycle times are four clock periods. A longer memorycycle will cause the || 
generation of wait states which must be added to the total instruction time. I 

The number of bus read and write cycles for each instruction is also included with I 
the timing data. This data is enclosed in parenthesis following the number of clock ■ 
periods and is shown as: (r/w) where r is the number of read cycles and w is the “ 
number of write cycles includedin the clock period number. Recalling that either a 
read or write cycle requires four clock periods, a timing number given as 18 (3/1) - 
relates to 12 clock periods for the three read cycles, plus 4 clock periods for the one n 
write cycle, plus 2 cycles required for some internal function of the processor. j 

Note; ® 

J 

The number of periods includes instruction fetch and all applicable operand | 
fetches and stores. J 


VMPU-237 



TOSHIBA 


TLCS-68000 


j E.2 OPERAND EFFECTIVE ADDRESS CALCULATION TIMES 

Table E.l lists the number of clock periods required to compute an instruction’s 
I effective address. It includes fetching of any extension words, the address 

I computation, and fetching of the memory operand. The number of bus read and 

I write cycles is shown in parenthesis as (r/w). Note there are no write cycles involved 
I in processing the effective address. 


Table E.l Effective Address Calculation Times 



Addressing Mode 

Byte 

Word 

Long word 



Register 








Dn 

Data Register Direct 

0 

(0/0) 

0 

(0/0) 

0 

(0/0) 


An 

Address Register Direct 

0 

(0/0) 

0 

(0/0) 

0 

(0/0) 



Memory 








(An) 

Data Register Indirect 

4 

(1/0) 

8 

(2/0) 

16 

(4/0) 


(An) + 

Address Register Indirect with Postincrement 

4 

(1/0) 

8 

(2/0) 

16 

(4/0) 


-(An) 

Address Register indirect with Predecrement 

6 

(1/0) 

10 

(2/0) 

18 

(4/0) 


d16(An) 

Address Register indirect with Displacement 

12 

(3/0) 

16 

(4/0) 

24 

(6/0) 


d8 (An, Xn)* 

Address Register Indirect with index 

14 

(3/0) 

18 

(4/0) 

26 

(6/0) 


Abs.W 

Absolute Short 

12 

(3/0) 

16 

(4/0) 

24 

(6/0) 


Abs.L 

Absolute Long 

20 

(5/0) 

24 

(6/0) 

32 

(8/0) 


d16(PCj 

Program Counter with Displacement 

12 

(3/0) 

16 

(4/0) 

24 

(6/0) 


d8(PC, Xn)* 

Program Counter with index 

14 

(3/0) 

18 

(4/0) 

26 

(6/0) 


#<data> 

Immediate 

8 

(2/0) 

8 

(2/0) 

16 

(4/0) 


* : The size of the index register (Xn) does not affect execution time. 
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E.3 MOVE INSTRUCTION EXECUTION TIMES 

Table E.2, E.3 and E.4 indicate the number of clock periods for the move 
instruction. This data includes instruction fetch, operand reads, and operand writes. 
The number of bus read and write cycles is shown in parenthesis as (r/w). 


Table E.2 Move Byte Instruction Execution Times 


Source 

Destination | 

Dn 

An 

(An) 

(An) + 

-(An) 

die (An) 

68 (An,Xn)* 

Abs.W 

Abs.L 

Dn 

8(2/0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

20 (4/1) 

22(4/1) 

20 (4/1) 

28(6/1) 

An 

8(2/0) 

8 (2/0) 

12(2/1) 

12 (2/1) 

12(2/1) 

20 (4/1) 

22 (4/1) 

20 (4/1) 

28 (6/1) 

(An) 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

24 (5/1) 

26(5/1) 

24(5/1) 

32(7/1) 

(An) + 

12(3/0) 

12 (3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

24 (5/1) 

2e(5/i) 

24(5/1) 

32 (7/1) 

-(An) 

14(3/0) 

14(3/0) 

18(3/1) 

18(3/1) 

18(3/1) 

26(5/1) 

28 (5/1) 

26(5/1) 

34 (7/1) 

die (An) 

20 (5/0) 

20 (5/0) 

24 (5/1) 

24 (5/1) 

24 (5/1) 

32(7/1) 

34 (7/1) 

32(7/1) 

40 (9/1) 

d8(An, Xn)* 

22 (5/0) 

22 (5/0) 

26(5/1) 

26(5/1) 

26(5/1) 

34 (7/1) 

36 (7/1) 

34(7/1) 

42 (9/1) 

Abs.W 

20 (5/0) 

20 (5/0) 

24(5/1) 

24(5/1) 

24 (5/1) 

32 (7/1) 

34 (7/1) 

32 (7/1) 

40(9/1) 

Abs.L 

28 (7/0) 

28 (7/0) 

32(7/1) 

32 (7/1) 

32(7/1) 

40 (9/1) 

42 (9/1) 

40 (9/1) 

48(11/1) 

die (PC) 

20 (5/0) 

20 (5/0) 

24(5/1) 

24(5/1) 

24(5/1) 

32 (7/1) 

34 (7/1) 

32 (7/1) 

40 (9/1) 

d8(PC, Xn)* 

22 (5/0) 

22 (5/0) 

26(5/1) 

26(5/1) 

26(5/1) 

34 (7/1) 

36 (7/1) 

34 (7/1) 

42 (9/1) 

#<data> 

16(4/0) 

16(4/0) 

20 (4/1) 

20(4/1) 

20(4/1) 

28 (6/1) 

30(6/1) 

28(6/1) 

36(8/1) 


* : The size of the index register (Xn) does not affect execution time. 


Table E.3 Move Word Instruction Execution Times 


Source 

Destination | 

Dn 

An 

. (An) _ 

(An) + 

-(An) 

die (An) 

d8 (An,Xn)* 

Abs.W 

Abs.L 

Dn 

8(2/0) 

8(2/0) 

16(2/2) 

16(2/2) 

16(2/2) 

24 (4/2) 

26 (4/2) 

20 (4/2) 

32 (6/2) 

An 

8(2/0) 

8(2/0) 

16(2/2) 

16(2/2) 

16(2/2) 

24 (4/2) 

26 (4/2) 

20 (4/2) 

32 (6/2) 

(An) 

16(4/0) 

16(4/0) 

24 (4/2) 

24(4/2) 

24 (4/2) 

32 (6/2) 

34 (6/2) 

32 (6/2) 

40 (8/2) 

(An) + 

16(4/0) 

16(4/0) 

24 (4/2) 

24 (4/2) 

24 (4/2) 

32 (6/2) 

34 (6/2) 

32 (6/2) 

40 (8/2) 

-(An) 

18(4/0) 

18(4/0) 

26 (4/2) 

26 (4/2) 

26 (4/2) 

34 (6/2) 

32 (6/2) 

34 (6/2) 

42 (8/2) 

die (An) 

24 (6/0) 

24 (6/0) 

32 (6/2) 

32 (6/2) 

32 (6/2) 

40 (8/2) 

44 (8/2) 

40 (8/2) 

48(10/2) 

d8(An, Xn)* 

26 (6/0) 

26 (6/0) 

34 (6/2) 

34 (6/2) 

34 (6/2) 

42 (8/2) 

44 (8/2) 

42 (8/2) 

50 (10/2) 

Abs.W 

24 (6/0) 

24 (6/0) 

32 (6/2) 

32 (6/2) 

32 (6/2) 

40 (8/2) 

42 (8/2) 

40 (8/2) 

48 (10/2) 

Abs.L 

32 (8/0) 

32 (8/0) 

40 (8/2) 

40 (8/2) 

40 (8/2) 

48(10/2) 

o 

o 

00 

o 

— 

56(12/2) 

d16(PC) 

24 (6/0) 

24 (6/0) 

32 (6/2) 

32 (6/2) 

32 (6/2) 

40 (8/2) 

42 (8/2) 

40 (8/2) 

48(10/2) 

d8(PC, Xn)* 

26 (6/0) 

26 (6/0) 

34 (6/2) 

34 (6/2) 

34 (6/2) 

42 (8/2) 

44 (8/2) 

42 (8/2) 

50 (10/2) 

#<data> 

16(4/0) 

16(4/0) 

24 (4/2) 

24 (4/2) 

24 (4/2) 

32 (6/2) 

34 (6/2) 

32 (6/2) 

40 (8/2) 


The size of the index register (Xn) does not affect execution time. 
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Table E.4 Move Long Word Instruction Execution Times 




Dn 

An 

(An) 

(An) + 

-(An) 

d16(An) 

(d8(An,Xn)* 

Abs.W 



8(2/0) 

8(2/0) 

24 (2/4) 

24 (2/4) 

24 (2/4) 

32 (4/4) 

34 (4/4) 

32 (4/4) 

40 (6/4) 


8(2/0) 

8(2/0) 

24 (2/4) 

24 (2/4) 

24 (2/4) 

32 (4/4) 

34 (4/4) 

32 (4/4) 

40 (6/4) 


24(6/0) 

24 (6/0) 

40 (6/4) 

40 (6/4) 

40 (6/4) 

48 (8/4) 


48 (8/4) 

56(10/4) 

{An) + 

24 (6/0) 

24 (6/0) 

40 (6/4) 

40 (6/4) 

40 (6/4) 

48 (8/4) 

50 (8/4) 

48 (8/4) 

56(10/4) 

-(An) 

26 (6/0) 

26 (6/0) 

42 (6/4) 

42 (6/4) 

42 (6/4) 

50 (8/4) 

52 (8/4) 

50 (8/4) 

58(10/4) 

d16(An) 

32 (8/0) 

32 (8/0) 

48 (8/4) 

48 (8/4) 

48 (8/4) 

56(10/4) 

58(10/4) 

56(10/4) 

64(12/4) 

d8 (An, Xn)* 

34 (8/0) 

34 (8/0) 

50 (8/4) 

50 (8/4) 

50 (8/4) 

58(10/4) 

60(10/4) 

58(10/4) 

66(12/4) 

Abs.W 

32 (8/0) 

32 (8/0) 

48 (8/4) 

48 (8/4) 

48 (8/4) 

56(10/4) 

58(10/4) 

56(10/4) 

64(12/4) 

Abs.L 

40(10/0) 

40(10/0) 

56(10/4) 

56(10/4) 

56(10/4) 

64(12/4) 

66(12/4) 

64(12/4) 

72(14/4) 

die (PC) 

32 (8/0) 

32 (8/0) 

48 (8/4) 

48 (8/4) 

48 (8/4) 

56(10/4) 

58(10/4) 

56(10/4) 

64(12/4) 

d8(PC, Xn)* 

34 (8/0) 

34 (8/0) 

50 (8/4) 

50 (8/4) 

50 (8/4) 

58(10/4) 

60(10/4) 

58(10/4) 

66(12/4) 

#<data> 

24 (6/0) 

24 (6/0) 

40 (6/4) 

40 (6/4) 

40 (6/4) 

48 (8/4) 

50 (8/4) 

48 (8/4) 

56(10/4) 


* : The size of the index register (Xn) does not affect execution time. 

E.4 STANDARD INSTRUCTION EXECUTION TIMES 


The number of clock periods shown in Table E.5 indicates the time required to 
perform the operations, store the results, and read the next instruction. The number 
of bus read and write cycles is shown in parenthesis as (r/w). The number of clock 
periods and the number of read and write cycles must be added respectively to those 
of the effective address calculation where indicated. In Table E.5 the 
the following meanings: An = address register operand, Dn = 
operand, ea =an operand specified by an effective address, and 
effective address operand. 


headings have 
data register 
M = memory 
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Table E.5 Standard Instruction Execution Times | 


Instruction 

Size 

op<ea>. An 

op<ea>, Dn 

op Dn, <M> 


Byte 

- 

8 (2/0) + 

12 (2/1) + 

ADD/ADDA 

Word 

12(2/0) + 

8 (2/0) + 

16 (2/2) + 


Long word 

10(2/0) + ** 

10 (2/0) +** 

24 (2/4) + 


Byte 

- 

8 (2/0) + 

12 (2/1) + 

AND 

Word 

- 

8 (2/0) + 

16 (2/2) + 


Long word 

- 

10 (2/0) +** 

24 (2/4) + 


Byte 

- 

8 (2/0) + 

- 

CMP/CMPA 

Word 

10(2/0) + 

8 (2/0) + 

- 


Long word 

10(2/0) + 

10 (2/0) + 


DIVS 


- 

162 (2/0) * 

- 

DIVU 


- 

144 (2/0) * 

- 


Byte 

- 

8 (2/0) +*** 

12 (2/1) + 

EOR 

Word 

- 

8 (2/0) +*** 

16 (2/2) + 


Long word 

- 

12 (2/0) +*** 

24 (2/4) + 

MULS 


- 

74 (2/0) +* 

- 

MULU 


- 

74 (2/0) +* 

- 


Byte 

- 

8 (2/0) + 

12 (2/1) + 

OR 

Word 

- 

8 (2/0) + 

16 (2/2) + 


Long word 

- 

10 (2/0) +** 

24 (2/4) + 


Byte 

- 

8 (2/0) + 

12 (2/1) + 

SUB 

Word 

12 (2/0) + 

8 (2/0) + 

16 (2/2) + 


Long word 

10(2/0) + ** 

10 (2/0) ** 

24 (2/4) + 


Notes: 


+ : add effective address calculation time | 

* : Indicates maximum base value added to word effective address time. | 

** : The base time of 10 clock periods is increased to 12 if the effective address I 

mode is register direct or immediate ^ 

(effective address time should also be added). ® 

*** Only available effective address mode is data register direct. ^ 

DIVS, DIVU — The divide algorithm used by the TMP68008 provides less than g 

10% difference between the best and worst case timings. i 


MULS, MULU — The multiply algorithm requires 42 + 2n clocks where n is defined | 

as: ] 

MULS n = tag the <ea> with a zero as the MSB; n is the resultant number I 

of 10 or 01 patterns in the 17-bit source, i.e., worst case happens 1 

when the source is $5555. ® 

I 

MULU n = the number of ones in the < ea > 

I 

I 
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E.5 IMMEDIATE INSTRUCTION EXECUTION TIMES 

The number of clock periods shown in Table E.6 includes the time to fetch 
immediate operands, perform the operations,store the results, and read the next 
operation. The number of bus read and write cycles is shown in parenthesis as (r/w). 
The number of clock periods and the number of read and write cycles must be added 
respectively to those of the effective address calculation where indicated. In Table 
E.6, the headings have the foilwing meanings: # = immediate operand, Dn = data 
register operand, An= address register operand, and M = memory operand. 


Table E.6 Immediate Instruction Execution Times 


Instruction 

Size 

op #, Dn 

op #, An 

op #, M 


Byte 

16 (4/0) 

- 

20 (4/1) + 

ADDI 

Word 

16 (4/0) 

- 

24 (4/2) + 


Long word 

28 (6/0) 

- 

40 (6/4) + 


Byte 

8 (2/0) 

- 

12 (2/1) + 

ADDQ 

Word 

8 (2/0) 

12 (2/0) 

16 (2/2) + 


Lon word 

12 (2/0) 

12 (2/0) 

24 (2/4) + 


Byte 

16 (4/0) 

- 

20 (4/1) + 

AND! 

Word 

16 (4/0) 

- 

24 (4/2) + 


Lon word 

28 (6/0) 

- 

40 (6/4) + 


Byte 

16 (4/0) 

- 

16 (4/0) + 

CMPI 

Word 

16 (4/0) 

- 

16 (4/0) + 


Lon word 

26 (6/0) 

- 

24 (6/0) + 


Byte 

16 (4/0) 

- 

20 (4/1) + 

EORI 

Word 

16 (4/0) 

- 

24 (4/2) + 


Lon word 

28 (6/0) 

- 

40 (6/4) + 

MOVEQ 

Lon word 

8 (2/0) 

- 

- 


Byte 

16 (4/0) 

- 

20 (4/1) + 

ORI 

Word 

16 (4/0) 

- 

24 (4/2) + 


Lon word 

28 (6/0) 

- 

40 (6/4) + 


Byte 

16 (4/0) 


12 (2/1) + 

SUBI 

Word 

16 (4/0) 

- 

16 (2/2) + 


Lon word 

28 (6/0) 

- 

24 (2/4) + 


Byte 

8 (2/0) 

- 

20 (4/1) + 

SUBQ 

Word 

8 (2/0) 

12 (2/0) 

24 (4/2) + 


Lon word 

12 (2/0) 

12 (2/0) 

40 (6/4) + 


+ : add effective address calculation time 
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E.6 SINGLE OPERAND INSTRUCTION EXECUTION TIMES | 

Table E.7 indicates the number of clock periods for the single operand ^ 
instructions. The number of bus read andwrite cycles is shown in parenthesis as j 
(r/w). The number of clock periods and the number of read and write cycles must be | 
added respectively to those of the effective address calculation where indicated. j 

1 

I 

I 
I 

I 
I 

I 
1 
I 
1 

I 
1 
1 
1 
1 
1 
I 
I 
I 
I 
1 

+ : add effective address calculation time. ^ 
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E.7 SHIFT/ROTATE INSTRUCTION EXECUTION TIMES 

Table E.8 indicates the number of clock periods for the shift and rotate 
instructions. The number of bus read and write cycles is shown in parenthesis as 
(r/w). The number of clock periods and the number of read and write cycles must be 
added respectively to those of the effective address calculation where indicated. 


Table E.8 Shift/Rotate Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

ASR, ASL 

Byte 

Word 

Long word 

10 + 2n (2/0) 

10 + 2n(2/0) 

12 + 2n (2/0) 

16(2/2) + 

LSR, LSI 

Byte 

Word 

Long word 

10 + 2n (2/0) 

10 + 2n (2/0) 

12 + 2n(2/0) 

16(2/2) + 

ROR, ROL 

Byte 

Word 

Long word 

10 + 2n(2/0) 

10 + 2n(2/0) 

12 + 2n(2/0) 

16(2/2) + 

ROXR, ROXL 

Byte 

Word 

Long word 

10 + 2n(2/0) 

10 + 2n (2/0) 

12 + 2n(2/0) 

16(2/2) + 


+ : add effective address calculation time for word operands 
n : is the shift count 


E.8 BIT MANIPULATION INSTRUCTION EXECUTION TIMES 

Table E.9 indicates the number of clock periods required for the bit manipulation 
instructions. The number of bus read and write cycles is shown in parenthesis as 
(r/w). The number of clock periods and the number of read and write cycles must be 
added respectively to those of the effective address calculation where indicated. 
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Table E .9 Bit Manipulation Instruction Execution Times 


Instruction 

Size 

Dynamic 

Static 

Register 

Memory 

Register 

Memory 

BCHG 

Byte 

Long word 

12 (2/0) * 

12 (2/1) + 

20 (4/0)* 

20 (4/1) + 

BCLR 

Byte 

Long word 

14 (2/0) * 

12 (2/1) + 

22 (4/0)* 

20 (4/1) + 

BSET 

Byte 

Long word 

12 (2/0) * 

12 (2/1) + 

20 (4/0)* 

20(4/1) + 

BIST 

Byte 

Long word 

10 (2/0) * 

8 (2/0) + 

18(4/0)* 

16(4/0) + 


+ : add effective address calculation time 

* : Indicates maximum value; data addressing mode only 

E.9 CONDITIONAL INSTRUCTION EXECUTION TIMES 


D 

I 

I 

I 

1 

I 

1 


1 

t 

j 


Table E.IO indicates the number of clock periods required for the conditional ] 
instructions. The number of bus read and write cycles is indicated in parenthesis as 1 
(r/w). The number of clock periods and the number of read and write cycles must be ^ 
added respectively to those of the effective address calculation where indicated. ^ 


Table E.IO Conditional Instruction Execution Times 


Instruction 

Displacement 

Trap or 

Branch Taken 

Trap or 

Branch Not taken 

Bcc 

Byte 

18 (4/0) 

12 (2/0) 

Word 

18 (4/0) 

20 (4/0) 

BRA 

Byte 

Word 

18 (4/0) 

18 (4/0) 

- 

BSR 

Byte 

34 (4/4) 

- 

Word 

34 (4/4) 

- 

DBcc 

ccTrue 

- 

20 (4/0) 

cc False 

18 (4/0) 

26 (6/0) 

CHK 

- 

68 (8/6) + * 

14 (2/0) + 

TRAP 

- 

62 (8/6) 

- 

TRAPV 


66 (10/6) 

8 (2/0) 


+ : add effective address calculation time for word operand 

* : indicates maximum base value 
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E.IO JMP, JSR, LEA, PEA, AND MOVEM INSTRUCTION EXECUTION TIMES 

Table E.ll indicates the number of clock periods required for the jump, jump-to- 
subroutine, load effective address, push effective address, and move multiple 
registers instructions. The number of bus read and write cycles is shown in 
parenthesis as (r/w). 


Table E.ll JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times 


n 


Size 

(An) 

(An) + 

-(An) 




Abs,L 

d16(PC) 

d8(PC, Xn)* 


JMP 

- 

16 (4/0) 

- 

- - 

18(4/0) 

22 (4/0) 

18(4/0) 

24 (6/0) 

18(4/0) 

22 (4/0) 


JSR 

- 

32 (4/4) 

- 

- 

34 (4/4) 

38 (4/4) 

34 (4/4) 

40 (6/4) 

34 (4/4) 

32 (4/4) 


LEA 

- 

8 (2/0) 

- 

- 

16(4/0) 

20 (4/0) 

16(4/0) 

24 (6/0) 

16(4/0) 

20 (4/0) 


PEA 

- 

24 (2/4) 

- 

- 

32 (4/4) 

36 (4/4) 

32 (4/4) 

40 (6/4) 

32 (4/4) 

36(4/4) 



Word 

24 + 8n 

24 + 8n 

- 

32 + 8n 

34 + 8n 

32 + 8n 

40 + 8n 

32 + 8n 

34 + 8n 


MOVEN 


(6 + 2n/0) 

(6 + 2n/0) 

- 

(8 + 2n/0) 

(8 + 2n/0) 

(lO + n/O) 

(10 + 2n/0) 

(8 + 2n/0) 

(8 + 2n/0) 


N-^R 

Long word 

24+ 16n 

24 + 16n 

- 

32 + 16n 

34+ 16n 

32 + 16n 

40 +16n 

32 + 16n 

32 + 16n 




(6 + 4n/0) 

(6 + 4n/0) 

- 

(8 + 4n/0) 

(8 + 4n/0) 

(8 + 4n/0) 

(8 + 4n/0) 

(8 + 4n/0) 

(8 + 4n/0) 



Word 

16 + 8n 

- 

16 +8n 

24 + 8n 

26 + 8n 

24 + 8n 

32 + 8n 

- 

- 


MOVEN 


(4/2 n) 

- 

(4/2 n) 

(6/2 n) 

(6/2 n) 

(6/2 n) 

(8/2n) 

- 

- 


R-^N 

Long word 

16 + 16n 

- 

16+16n 

24+16n 

26 + 16n 

24+ 16n 

32+16n 

- 

- 




(4/4n) 

- 

. (4/4n) 

(6/4n) 


(8/4 n) 

(6/4n) 

- 

- 


n: the number of registersto move 

* ; the size of the index register (Xn) does not affect the instruction's execution time 
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E.ll MULTI-PRECISION INSTRUCTION EXECUTION TIMES 

Table E.12 indicates the number of clock periods for the multi-precision 
instructions. The number of clock periods includes the time to fetch both operands, 
perform the operations, store the results, and read the next instructions. The. 
number of bus read and write cycles is shown in parenthesis as (r/w). 


Table E.12 Multi-Precision Instruction Execution Times 


Instruction 

Size 


0PM, M 


Byte 

8(2/0) 

22(4/1) 

ADDX 

Word 

8(2/0) 

50 (6/2) 


Long word 

12(2/0) 

58(10/4) 


Byte 

- 

16(4/0) 

CMPM 

Word 

- 

24 (6/0) 


Long word 

- 

40(10/0) 


Byte 

8(2/0) 

22 (4/1) 

SUBX 

Word 

8 (2/0) 

50 (6/2) 


Long word 

12(2/0) 

58(10/4) 

ABCD 

Byte 

10(2/0) 

20 (4/1) 

SBCD 

Byte 

10(2/0) 

20(4/1) 
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j E.12 MISCELLANEOUS INSTRUCTION EXECUTION TIMES 

Table E.13 and E.14 indicate the number of clock periods for the folowing 
I miscellaneous instructions. The number of bus read and write cycles is shown in 

I parenthesis as: (r/w). The number of clock periods plus the number of read and write 

I cycles must be added to those of the effective address calculation where indicated. 

I Table E.13 Miscellaneous Instruction Execution Times 


Instruction 

Register 

Memory 

ANDI to CCR 

32 (6/0) 

- 

ANDl to SR 

32 (6/0) 

- 

EORI to CCR 

32 (6/0) 

- 

EORI to SR 

32 (6/0) 

- 

EXG 

10(2/0) 

- 

EXT 

8 (2/0) 

- 

LINK 

32 (4/4) 

- 

MOVE to CCR 

18(4/0) 

18(4/0) + 

MOVE to SR 

18(4/0) 

18(4/0) + 

MOVE from 

SR 

10(2/0) 

16(2/2) + 

MOVE to USP 

8 (2/0) 

- 

MOVE from 

USP 

8 (2/0) 

- 

NOP 

8(2/0) 

- 

ORl to CCR 

32 (6/0) 

- 

ORI to SR 

32 (6/0) 

- 

RESET 

136(2/0) 

- 

RTE 

40(10/0) 

- 

RTR 

40(10/0) 

- 

RTS 

32 (8/0) 

- 

STOP 

4 (0/0) 

- 

SWAP 

8(2/0) 

- 

UNLK 

24 (6/0) 

- 


+ : add effective address calculation time for word operand 


Table E.14 Move Peripheral Instruction Execution Times 


Instruction 

Size 

Register—^Memory 

Memory-^Register 

MOVER 

Word 



Long word 




+ : add effective address calculation time 
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E.13 EXCEPTION PROCESSING EXECUTION TIMES 

Table E.15 indicates the number of clock periods for exception processing. The 
number of clock periods includes the time for all stacking, the vector fetch, and the 
fetch of the first instruction of the handler routine. The number of bus read and 
write cycles is shown in parenthesis as: (r/w). 

Table E.15 Exception Processing Execution Times 


I 

I 

I 

! 

I 

I 

1 


Exception 

Periods 

Address Error 

94 (8/14) 

Bus Error 

94 (8/14) 

CHK Instruction 

68 (8/6) + 

Divide by Zero 

66 (8/6) + 

Interrupt 

72 (9/6)* 

Illegal Instruction 

62 (8/6) 

Privileged Instruction 

62 (8/6) 

RESET** 

64(12/0) 

Trace 

62 (8/6) 

TRAP Instruction 

62 (8/6) 

TRAPV Instruction 

66(10/6) 


+ : add effective address calculation time 

** : Indicates the time from when RESET and HALT are first sampled as negated to 
when instruction execution starts. 
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APPENDIX F TMP68Q10 INSTRUCTION EXECUTION TIMES 

F.l INTRODUCTION 

This Appendix contains listings of the instruction execution times in terms of 
external clock (CLK) periods. In this data, it is assumed that both memory read and 
write cycle times are four clock periods. A longer memory cycle will cause the 
generation of wait states which must be added to the total instruction time. 

The number of bus read and write cycles for each instruction is also included with 
the timing data. This data is enclosed in parenthesis following the number of clock 
periods and is shown as: (r/w) where r is the number of read cycles and w is the 
number of write cycles included in the clock period number. Recalling that either a 
read or write cycle requires four clock periods, a timing number given as 18(3/1) 
relates to 12 clock periods for the three read cycles, puls 4 clock periods for the one 
write C3^cle, puls 2 cycles required for some internal function of the processor. 

Note: 

The number of periods includes instruction fetch and all applicable operand 
fetches and stores. 

F.2 OPERAND EFFECTIVE ADDRESS CALCULATION TIMES 

Table F.l lists the number of clock periods required to compute an instruction’s 
effective address. It includes fetching of any extension words if necessary. Several 
instructions do not need the operand at the effective address to be fetched and thus 
require fewer clock periods to calculate a given effective address than the 
instructions that fetch the effective address operand. The number of bus read and 
v/rite cycles is shown in parenthesis as (r/w). Note there are no write cycles involved 
in processing the effective address. 


VMPU-250 



TOSHIBA 


TLCS-S80Q0 


Table F.l Effective Address Calculation Times 



Addressing Mode 

Byte, Word 

Long word j 


Fetch 

No Fetch 

Fetch 

No Fetch j 

Dn 

An 

Register 

Data Register Direct 

Address Register Direct 

0(0/0) 

0(0/0) 


0(0/0) 

0(0/0) 

- 

(An) 

Memory 

Address Register Indirect 

4(1/0) 

2 (0/0) 

8(2/0) 

2 (2/0) 

(An) + 

Address Register Indirect with Postincrement 

4(1/0) 

4(0/0) 

8(2/0) 

4 (0/0) 

-An 

Address Register Indirect with Predecrement 

6(1/0) 

4(0/0) 

10(2/0) 

4 (0/0) 

d16{An) 

Address Register Indirect with Displacement 

8(2/0) 

4(0/0) 

12(3/0) 

4(1/0) 

d8(An, Xn)* 

Address Register Indirect with Index 

10(2/0) 

8(1/0) 

14(3/0) 

8(1/0) 

Abs.W 

Absolute Short 

8(2/0) 

4(1/0) 

12(3/0) 

4(1/0) j 

Abs.L 

Absolute Long 

12(3/0) 

8 (2/0) 

16(4/0) 

8 (2/0) 

die (PC) 

Program Counter with Displacement 

8(2/0) 

- 

12(3/0) 

- 

d8(PC, Xn)* 

Program Counter with Index 

10(2/0) 

- 

14(3/0) 

" 

#<data> 

Immediate 

4(1/0) 

- 

8 (2/0) 

1 


*: The size of the ipdex register (Xn) does not affect execution time. 


F.3 MOVE INSTRUCTION EXECUTION TIMES 

Table F.2, F.3, F.4 and F.5 indicate the number of clock periods for the move 
instruction. This data includes instruction fetch, operand reads, and operand 
writes. The number of bus read and write cycles is shown in parenthesis as (r/w). 


Table F.2 Move Byte and Word Instruction Execution Times 


Source 

Destination | 

Dn 

An 

(An) 

(An) + 

-(An) 

d16(An) 

d8(An,Xn)* 

Abs.W 

Abs.L I 

Dn 

4(1/0) 

4(1/0) 

8(1/1) 

8(1/1) 

8(1/1) 

12(2/1) 

14(2/1) 

12(2/1) 

16(3/1) 1 

An 

4(1/0) 

4(1/0) 

8(1/1) 

8(1/1) 

8(1/1) 

12(2/1) 

14(2/1) 

12(2/1) 

16 (.3/1) 1 

(An) 

8 (2/0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16(3/1) 

18(3/1) 

16(3/1) 

20(4/1) [ 

(An) + 

8 (2/0) 

8(2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16(3/1) 

18(3/1) 

16(3/1) 

20(4/1) 1 

-(An) 

10(2/0) 

10(2/0) 

14(2/1) 

14(2/1) 

14(2/1) 

18(3/1) 

20(3/1) 

18(3/1) 

22(4/1) I 

d16(An) 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

20(4/1) 

22(4/1) 

20(4/1) 

24(4/1) 1 

d8(An, Xn) * 

14(3/0). 

14(3/0) 

18(3/1) 

18(3/1) 

18(3/1) 

22 (4/1) 

24(4/1) 

22(4/1) 

26(5/1) 

Abs.W 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

20(4/1) 

22(4/1) 

20(4/1) 

24(5/1) \ 

Abs.L 

16(4/0) 

16(4/0) 

20(4/1) 

20 (4/1) 

20(4/1) 

24(5/1) 

26(5/1) 

24(5/1) 

28(6/1) 1 

d16(PC) 

12(3/0) 

12(3/0) 

16(3/1) 

16(3/1) 

16(3/1) 

20 (4/1) 

22(4/1) 

20(4/1) 

24(5/1) 1 

d8(PC, Xn) * 

14(3/0) 

14(3/0) 

18(3/1) 

18(3/1) 

18(3/1) 

22 (4/1) 

24(4/1) 

22(4/1) 

26(5/1) 

#<data> 

8 (2/0) 

8 (2/0) 

12(2/1) 

12(2/1) 

12(2/1) 

16(3/1) 

18(3/1) 

16(3/1) 

20(4/1) 


The size of the index register (Xn) does not affect execution time. 
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Table F.3 Move Byte and Word Instruction Loop Mode Execution Times 



Loop Continued 



Loop Terminated 




Valid Count, cc False 

Valid Count, ccTrue 

Expired Count | 

Source 

Destination 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

Dn 

10(0/1) 

10(0/1) 

- 

18(2/1) 

18(2/1) 

- 

16(2/1) 

16(2/1) 

- 

An* 

10(0/1) 

10(0/1) 

- 

18(2/1) 

18(2/1) 

- 

16(2/1) 

16(2/1) 

- 

(An) 

14(1/1) 

14(1/1) 

16(1/1) 

20 (3/1) 

20 (3/1) 

22(3/1) 

18(3/1) 

18(3/1) 

20(3/1) 

(An) + 

14(1/1) 

14(1/1) 

16(1/1) 

20 (3/1) 

20 (3/1) 

22 (3/1) 

18(3/1) 

18(3/1) 

20(3/1) 

-(An) 

16(1/1) 

16(1/1) 

18(1/1) 

22(3/1) 

22 (3/1) 

24 (3/1) 

20(3/1) 

20(3/1) 

22 (3/1) 

*: 

Table F.4 Move Long Word Instruction Execution Times 



Source 

Destination | 

Dn 

An 

(An) 

(An) + 

-(An) 

dl6 (An) 

d8 (An,Xn)* 

Abs.W 

Abs.L 

Dn 

4(1/0) 

4(1/0) 

12(1/2) 

12(1/2) 

14(1/2) 

16(2/2) 

18(2/2) 

16(2/2) 

20 (3 / 2) 

An 

4(1/0) 

4(1/0) 

12(1/2) 

12(1/2) 

14(1/2) 

16(2/2) 

18(2/2) 

16(2/2) 

20 (3/2) 

(An) 

12(3/0) 

12(3/0) 

20(3/2) 

20(3/2) 

20(3/2) 

24 (4/2) 

26(4/2) 

24 (4/2) 

28(5/2) 

(An) + 

12(3/0) 

12(3/0) 

20(3/2) 

20(3/2) 

20(3/2) 

24 (4/2) 

26 (4/2) 

24 (4/2) 

28(5/2) 

-(An) 

14(3/0) 

14(3/0) 

22(3/2) 

22(3/2) 

22 (3/2) 

26(4/2) 

28 (4/2) 

26(4/2) 

30(5/2) 

d 16 (An) 

16(4/0) 

16(4/0) 

24 (4/2) 

24 (4/2) 

24(4/2) 

28(5/2) 

30(5/2) 

28 (5/2) 

32 (6/2) 

d8 (An, Xn) * 

18(4/0) 

18(4/0) 

26(4/2) 

26(4/2) 

26 (4/2) 

30(5/2) 

32 (5 / 2) 

30(5/2) 

34 (6/2) 

Abs.W 

16(4/0) 

16(4/0) 

24 (4/2) 

24 (4/2) 

24 (4/2) 

28(5/2) 

30(5/2) 

28(5/2) 

32 (6/2) 

Abs.L 

20(5/0) 

20(5/0) 

28(5/2) 

28(5/2) 

28(5/2) 

32(6/2) 

34 (6/2) 

32 (6/2) 

36 (7 / 2) 

die (PC) 

16(4/0) 

16(4/0) 

24 (4/2) 

24 (4/2) 

24 (4/2) 

28(5/2) 

30(5/2) 

28(5/2) 

32 (6/2) 

d8 (PC, Xn) * 

18(4/0) 

18(4/0) 

26(4/2) 

26(4/2) 

26 (4/2) 

30(5/2) 

32(5/2) 

30(5/2) 

34(6/2) 

#<data> 

12(3/0) 

12(3/0) 

20 (3/2) 

20 (3 / 2) 

20 (3 / 2) 

24 (4/2) 

26(4/2) 

24 (4/2) 

28(5/2) 

1 * ; The size of the index register (Xn) does not affect execution 





Table F.5 

Move Long Word Instruction Loop Mode Execution Times 



Loop Continued 

Loop Terminated | 


Valid Count, cc False 

Valid Count, cc True | 

Expired Count | 

Source 

Destination 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

Dn 

14(0/2) 

14(0/2) 

- 

20 (2/2) 

20(2/2) 

- 

18(2/2) 

18(2/2) 

- 

An 

14(0/2) 

14(0/2) 

- 

20 (2 / 2) 

20(2/2) 

- 

18(2/2) 

18(2/2) 


(An) 

22 (2 / 2) 

22 (2 / 2) 

24 (2/2) 

28 (4/2) 

28(4/2) 

30(4/2) 

24 (4/2) 

24 (4/2) 

26(4/2) 

(An) + 

22 (2/2) 

22 (2/2) 

24 (2/2) 

28 (4/2) 

28 (4/2) 

30 (4/2) 

24 (4/2) 

24 (4/2) 

26(4/2) 

-(An) 

24 (2 / 2) 

24(2/2) 

26(2/2) 

30(4/2) 

30(4/2) 

32 (4/2) 

26(4/2) 

26 (4/‘2) 

28 (4/2) 
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F.4 STANDARD INSTRUCTION EXECUTION TIMES 

The number of clock periods shown in Tables F.6 and F.7 indicate the time 
required to perform the operations, store the results, and read the next instruction. 
The number of bus read and write cycles is shown in parenthesis as (r/w). The 
number of clock periods and the number of read and write cycles must be added 
respectively to those of the effective address calculation where indicated. 

In Tables F.6 and F.7 the headings have the following meanings: An = address 
register operand, Dn = data register operand, ea. =an operand specified by an 
effective address, and M = memory effective address operand. 


Table F.6 Standard Instruction Execution Times 


Instruction 

Size 

op<ea>. An*** 

op<ea>, Dn 

op Dn, <M> 

ADD/ADDA 

Byte, Word 

8(1 /O) + 

4(1/0) + 

8(1/1) + 

Long word 

6(1 /O) + 

6(1/0) + 

12(1/2) + 

AND 

Byte, Word 

- 

4(1/0) + 

8(1/1) + 

Long 

- 

6(1/0) + 

12(1/2) + 

CMP/CMPA 

Byte, Word 

6(1 /O) + 

4(1/0) + ' 

- 

Long word 

6(1 /O) + 

6(1/0) + 

- 

DIVS 

- • 

- 

122(1/0) + 

- 

DIVU 

- 

- 

108(1/0) + 

- 

EOR 

Byte, Word 

- 

4(1/0) ** 

8(1/1) + 

Long word 

- 

6(1 /O) ** 

12(1/2) + 

MULS 

- 

- 

42(1/0) + 

- 

MULU 

- 

- 

40(1/0) + 

- 

OR 

Byte, Word 

- 

4(1/0) + 

8(1/1) + 

Long word 

- 

6(1/0) + 

12(1/2) + 

SUB/SUBA 

Byte, Word 

8(1 /O) + 

4(1/0) + 

8(1/1) + 

Long word 

6(1/0) + 

6(1/0) + 

12(1/2) + 


Notes: 

+ : add effective address calculation time 

* : Indicates maximum value 

* * : only available addressing mode is data register direct 

* * * : word or long word only 
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Table F.7 Standard Instruction Loop Mode Execution Times 



Loop Continued 

Loop Terminated 

Valid Count, cc False 

Valid Count cc True 

Expired Count 

Instruc¬ 

tion 

Size 

op<ea> 

An* 

op<ea> 

Dn 

op Dn 
<ea> 

op<ea> 

An* 

op<ea> 

Dn 

op Dn 
<ea> 

op<ea> 

An* 

op<ea> 

Dn 

op Dn 
<ea> 

ADD 

Byte, Word 

18(1/0) 

18(1/0) 

16(1/1) 

24 (3/0) 

22 (3/0) 

22 (3/1) 

22(3/0) 

20 (3/0) 

20(3/1) 

Long word 

22 (2 / 0) 

22 (2/0) 

24 (2/2) 

28 (4/0) 

28 (4/0) 

30(4/2) 

26(4/0) 

26(4/0) 

28 (4/2) 

AND 

Byte, Word 

- 

16(1/1) 

16(1/1) 

- 

22 (3/0) 

22 (3/1) 

- 

20 (3 / 0) 

20(3/1) 

Long word 

- 

22 (2/0) 

24 (2/2) 

- 

28 (4/0) 

30(4/2) 

- 

26(4/0) 

28 (4/2) 

CMP 

Byte, Word 

12(1/0) 

12(1/0) 

- 

18(3/0) 

18(3/0) 

- 

16(3/0) 

16(4/0) 


Long word 

18(2/0) 

18(1/0) 

- 

24 (4/0) 

24 (4/0) 

- 

20(4/1) 

20 (4/0) 


EOR 

Byte, Word 

- 

- 

16(1/0) 

- 

- 

22 (3/1) 

- 

- 

20(3/1) 

Long word 

- 

- 

24(2/2) 

- 

- 

30(4/2) 

- 

- 

28 (4/2) 

OR 

Byte, Word 

- 

16(1/0) 

16(1/0) 

- 

22 (3/0) 

22(3/1) 

- 

20 (3 / 0) 

20(3/1) 

Long word 

- 

22(2/0) 

24 (2 / 2) 

- 

28 (4/0) 

30(4/2) 

- 

26(4/0) 

28(4/2) 

SUB 

Byte, Word 

18(1/0) 

16(1/0) 

16(1/1) 

24 (3/0) 

22(3/0) 

22 (3/1) 

22 (3/0) 

20(3/0) 

20(3/1) 

Long word 

22 (2/0) 

20(2/0) 

24(2/2) 

28 (4/0) 

26 (4/0) 

30(4/2) 

26(4/1) 

24(4/0) 

28 (4/2) 


Word or long only.<ea> may be (An), (An)+ or —(An) only. Add two clock periods 
to the table value if <ea> is —(An). 


F.5 IMMEDIATE INSTRUCTION EXECUTION TIMES 

The number of clock periods shown in Table F.8 includes the time to fetch 
immediate operands, perform the operations, store the results, and read the next 
operation. The number of bus read and .write cycles is shown in parenthesis as (r/w). 
The number of clock periods and the number of read and write cycles must be added 
respectively to those of the effective address calculation where indicated. 

In Table F.8, the headings have the follwing meanings: # = immediate operand, 
Dn = data register operand, An= address register operand, and M = memory 
operand. 
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Table F.8 Immediate Instruction Execution Times 


Instruction 

Size 

op#, Dn 

op #, An 

op #, M 

ADDI 

Byte, Word 

8(2/0) 

- 

12 (2/1) + 

Long word 

14(3/0) 

- 

20 (3/2) + 

ADDQ 

Byte, Word 

4(1/0) 

4(1 /O) * 

8(1/1) + 

Long word 

8(1 /O) 

8(1 /O) 

12(1/2) + 

ANDI 

Byte, Word 

8(2/0) 

- 

12(2/1) + 

Long word 

14(3/0) 

- 

20(3/1) + 

CM PI 

Byte, Word 

8(2/0) 

- 

8(2/0) + 

Long word 

12(3/0) 

- 

12(3/0) + 

EORI 

Long word 

8(2/0) 

- 

12(2/1) + 

Byte, Word 

14(3/0) 

- 

20(3/2) + 

MOVEQ 

Long word 

4(1/0) 

- 

- 

ORI 

Byte, Word 

8(2/0) 

- 

12(2/1) + 

Long word 

14(3/0) 

- 

20(3/2) + 

SUBI 

Byte, Word 

8 (2 / 0) 


12(2/1) + 

Long word 

14(3/0) 

- 

20 (3/2) + 

SUBQ 

Byte, Word 

4(1 /O) 

4(1/0) * 

8(1/1) + 

Long word 

8(/0) 

8(1/0) 

12(1/2) + 


+ : add effective address calculation time 

* : word only 

F.6 SINGLE OPERAND INSTRUCTION EXECUTION TIMES 


Tables F.9, F.IO, and F.ll indicate the number of clock periods for the single 
operand instructions. The numberof bus read and write cycles is shown in 
parenthesis as (r/w). The number of clock periods and the number of read and write 
cycles must be added respectively to those of the effective address calculation where 
indicated. 


Table F.9 Single Operand Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

NBDC 

Byte 

6(1/0) 

8(1/1) + 

NEC 

Byte, Word 

4(1/0) 

8(1/1) + 

Long word 

6(1/0) 

12 (1/2) + 

NEGX 

Byte, Word 

4(1 /O) 

8(1/1) + 

Long word 

6(1 /O) 

12(1/2) + 

NOT 

Byte, Word 

4(1 /O) 

8(1/1) + 

Long word 

6(1/0) 

12(1/2) + 

See 

Byte, Faise 

4(1/0) 

8(1/1) +* 

Byte, True 

4(1/0) 

8(1/1) +* 

TAS 

Byte 

4(1/0) 

14(2/1) +* 

TST 

Byte, Word 

4(1/0) 

4(1/0) + 

Long word 

4(1/0) 

4(1 /O) + 


+ : add effective address calculation time. 

* : Use non-fetching effective address calculation time. 
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Table F.IO Clear Instruction Execution Times 


Inst. 

Size 

Dn 

An 

(An) 

(An) + 

-(An) 

die (An) 

d8 (An, Xn)* 

Abs. w 

Abs.L 

CLR 

Byte, Word 

4(1/0) 

- 

8(1/1) 

8(1/1) 

10(1/1) 

12(1/1) 

16(2/1) 

12(2/1) 

16(3/1) 

Long word 

6(1/0) 

- 

12(1/2) 

12(1/2) 

14(1/2) 

16(2/2) 

20(2/2) 

16(2/2) 

20(3/2) 


The size of the index register (Xn) does not affect execution time. 


Table F.ll Single Operand Instruction Loop Mode Execution Times 



Loop Continued 

Loop Terminated 

Valid Count, cc False 

Valid Count, cc True 

Expired Count 

Inst. 

Size 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

CLR 

Byte, Word 

10(0/1) 

10(0/1) 

12(0/1) 

18(2/1) 

18(2/1) 

20(2/0) 

16(2/1) 

16(2/1) 

18(2/1) 

Long word 

14(0/2) 

14(0/2) 

16(0/2) 

22(2/2) 

22 (2 / 2) 

24 (2 / 2) 

20(2/2) 

20(2/2) 

22(2/2) 

NBCD 

Byte 

18(1/1) 

18(1/1) 

20(1/1) 

24 (3/1) 

24 (3/1) 

26(3/1) 

22 (3/1) 

22(3/1) 

24(3/1) 

NEC 

Byte, Word 

16(1/1) 

16(1/1) 

18(2/2) 

22 (3/1) 

22 (3/1) 

24 (3/1) 

20(3/1) 

20(3/1) 

22 (3/1) 

Long word 

24(2/2) 

24 (2/2) 

26(2/2) 

30 (4/2) 

30(4/2) 

32(4/2) 

28 (4/2) 

28 (4/2) 

30(4/2) 

NEGX 

Byte, Word 

16(1 /1) 

16(1/1) 

18(2/2) 

22 (3/1) 

22 (3/1) 

24(3/1) 

20(3/1) 

20(3/1) 

22(3/1) 

Long word 

24 (2/2) 

24(2/2) 

26(2/2) 

30 (4/2) 

30 (4/2) 

32(4/2) 

28 (4/2) 

28 (4/2) 

30 (4/2) 

NOT 

Byte, Word 

16(1/1) 

16(1/1) 

18(2/2) 

22(3/1) 

22 (3/1) 

24 (3/1) 

20(3/1) 

20 (3/1) 

22(3/1) 

Long word 

24(2/2) 

24(2/2) 

26(2/2) 

30(4/2) 

30 (4/2) 

32 (4/2) 

28 (4/2) 

28(4/2) 

30(4/2) 

TST ' 

Byte, Word 

12(1/0) 

12(1/0) 

14(1/0) 

18(3/0) 

18(3/0) 

20 (3/0) 

16(3/1) 

16(3/1) 

18(3/0) 

Long word 

18(2/0) 

18(2/0) 

20 (2/0) 

24 (4/0) 

24 (4/0) 

26(4/0) 

20(4/0) 

20(4/0) 

22(4/0) 
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F.7 SHIFT/ROTATE INSTRUCTION EXECUTION TIMES 

Tables F.12 and F.13 indicate the number of clock periods for the shift and rotate 
instructions. The number of bus read and write cycles is shown in parenthesis as 
(r/w). The number of clock periods and the number of read and write cycles must be 
added respectively to those of the effective address calculation where indicated. 


Table F.12 Shift/Rotate Instruction Execution Times 


Instruction 

Size 

Register 

Memory* 

FSR, ASL 

Byte, Word 

6 + 2n (1/0) 

8(1/1) + 

Long word 

8 + 2n(1/0) 

- 

LSR, LSI 

Byte, Word 

6 + 2n (1/0) 

8(1/1) + 

Long word 

8 + 2n (1 /O) 

- 

ROR, ROL 

Byte, Word 

6 + 2n (1/0) 

8(1 / I) + 

Long word 

8 + 2n (1/0) 

- 

ROXR, ROXL 

Byte, Word 

6 + 2n (1/0) 

8(1/1) + 

Long word 

8 + 2n(1/0) 

- 


+ : add effective address calculation time 
n : the shift or rotate count 
* : word only 


Table F.13 Shift/Rotate Instruction Loop Mode Execution Times 



Loop Continued 

Loop Terminated | 

Valid Count, cc False 

Valid Count, cc True 

Expired Count 

Instruction 

Size 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

(An) 

(An) + 

-(An) 

A5R, ASL 

Word 

18(1/1) 

18(1/1) 

20(1/1) 

24 (3/1) 

24 (3/1) 

26(3/1) 

22 (3/1) 

22 (3/1) 

24 (3/1) 

LSR, LSL 

Word 

18(1/1) 

18(1/1) 

20(1/1) 

24 (3/1) 

24 (3/1) 

26(3/1) 

22(3/1) 

22(3/1) 

24(3/1) 

ROR. ROL 

Word 

18(1/1) 

18(1/1) 

20(1/1) 

24 (3/1) 

24(3/1) 

26(3/1) 

22(3/1) 

22(3/1) 

24 (3/1) 

ROXR, ROXL 

Word 

18(1/1) 

18(1/1) 

20(1/1) 

24 (3/1) 

24 (3/1) 

26(3/1) 

22 (VD 

22 (3/1) 

24(3/1) 


■y 


F.8 BIT MANIPULATION INSTRUCTION EXECUTION TIMES 

Table F.14 indicates the number of clock periods required for the bit 
manipulation instructions. The number of bus read and write cycles is shown in 
parenthesis as (r/w). The number of clock periods and the number of read and write 
cycles must be added respectively to those of the effective address calculation where 
indicated. 
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Table F.14 Bit Manipulation Instruction Execution Times 


Instruction 

Size 

Dynamic 

Static 

Register 

Memory 

Register 

Memory 

BCHG 

Byte 

- 

8(1/1) + 

- 

12 (2/1) + 

Long word 

8(1/0)* 

- 

12(2/0)* 

- 

BCLR 

Byte 

- 

10(1/1) + 


14(2/1) + 

Long word 

10(1/0)* 


14(2/0)* 

- 

BSET 

Byte 

- 

8(1/1) + 


12 (2/1) + 

Long word 

8(1/0)* 

- 

12(2/0)* 

- 

BIST 

Byte 

-> 

4(1/0) + 

- 

8(2/0) + 

Long word 

6(1/0)* 

- 

10(2/0)* 

- 


+ : add effective address calculation time. 


: indicates maximum value 


F.9 CONDITIONAL INSTRUCTION EXECUTION TIMES 

Table F.15 indicates the number of clock periods required for the conditional 
instructions. The number of bus read and write cycles is indicated in parenthesis as 
(r/w). The number of clock periods and the number of read and write cycles must be 
added respectively to those of the effective address calculation where indicated. 


Table F.15 Conditional Instruction Execution Times 


Instruction 

Displacement 

Branch Taken 

Branch NotTaken 

Bcc 

Byte 

10(2/0) 

6(1 /O) 

Word 

10(2/0) 

10(2/0) 

BRA 

Byte 

10(2/0) 

— 

Word 

10(2/0) 

- 

BSR 

Byte 

18(2/2) 

- 

Word 

18(2/2) 

- 

DBcc 

cctrue 

- 

10(2/2) 

cc false 

10(2/2) 

16(3/0) 


+ : add effective address calculation time. 
* : indicates maximum value 
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F.IO JMP, JSR, LEA, PEA, AND MQVEM INSTRUCTION EXECUTION TIMES 

Table F.16 indicates the number of clock periods required for the jump, jump-to- 
subroutine, load effective address, push effective address, and move multiple 
registers instructions. The number of bus read and write cycles is shown in 
parenthesis as (r/w). 


Table F.16 JMP, JSR, LEA, PEA, and MQVEM Instruction Execution Times 


Inst. 

Size 

An 

(An) + 

- (An) 

d 16 (An) 

d8{An,Xn)* 

Abs.W 

Abs.L 

d16(PC) 

d8 (PC,Xn)* 

JMP 

- 

8(2/0) 

- 

- 

10(2/0) 

14(3/0) 

10(2/0) 

12(3/0) 

10(2/0) 

14(3/0) 

JSR 

- 

16(2/2) 

- 

- 

18(2/2) 

22 (2/2) 

18(2/2) 

20 (3/2) 

18(2/2) 

22(2/2) 

LEA 

- 

4(1/0) 

- 

- 

8 (2/0) 

12(2/0) 

20 (2/2) 

8(2/0) 

16(2/2) 

12(3/0) 

20 (3/2) 

8 (2/0) 

16(2/2) 

12(2/0) 

20 (2/2) 

PEA 

- 

12(1/2) 

- 

- 

16(2/2) 

MOVEM 

M ^R 

Word 

12 + 4n 

(3 + n/0) 

12 + 4n 

(3 + n/0) 

— 

16 + 4n 

(4 + n/0) 

18 + 4n 

(4 + n/0) 

16 + 4n 

(4 + n/0) 

20 + 4n 

(5 + n/0) 

16 + 4n 

(4 + n/0) 

18 + 4n 

(4 + n/0) 

Long 

word 

12 + 8n 

(3 + 2 n/0) 

12 + 8n 

(3 + 2n/0 

— 

16 + 8n 

(4 + 2n/0) 

18 + 8n 

(4 + 2 n/0) 

16 + 8n 

(4 + 2 n/0) 

20 + 8n 

(5 + n/0) 

16 + 8n 

(4 + 2 n/0) 

• 16 + 8n 

(4 + 2 n/0) 

MOVEM 

R-^M 

Word 

8 + 4n 

(2/n) 

- 

8 + 4n 

(2/n) 

12 + 4n 

(3/n) 

14 + 4n 

(3 + n) 

12 + 4n 

(3/n) 

16 + 4n 

(4/n) 

— 

— 

Long 

word 

8 + 8n 

(2/2n) 

- 

8 + 8n 

(2/2.1) 

12 + 8n 

(3/2n) 

14 + 8n 

(3/2n) 

12 + 8n 

(3/2n) 

16 + 8n 

(4/n) 

— 

— 

MOVES 

M-)R 

Byte, 

Word 

18(3/0) 

20(3/0) 

20(3/0) 

20 (4/0) 

24(4/0) 

20 (4/0) 

24 (5/0) 

— 

— 

Long 

word 

22(4/0) 

24(4/0) 

24(4/0) 

24 (5/0) 

28(5/0) 

24 (5/0) 

28(6/0) 

— 

— 

MOVES 

R-^M 

Byte, 

Word 

18(2/1) 

20(2/1) 

20(2/1) 

20 (3/1) 

24 (3/1) 

20(3/1) 

24(4/1) 

— 

— 

Long 

word 

22 (2/2) 

24 (2/2) 

24 (2/2) 

24 (3/2) 

28(3/21) 

24 (3/2) 

28 (4/2) 




n : The number of registers to move. 

* : The size of the index register (ix) does not affect the instruction’s execution time. 


F.ll MULTI-PRECISION INSTRUCTION EXECUTION TIMES 

Table F.17 indicates the number of clock periods for the multi-precision 
instructions. The number of clock periods includes the time to fetch both operands, 
perform the operations, store the results, and read the next instructions. The 
number of read and write cycles is shown in parenthesis as (r/w). 

In Table F.17, the headings have the following meanings: Dn = data register 
operand and M = memory operand. 
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Table F.17 Multi-Precision Instruction Execution Times 



Non-Looped 

Loop Mode 

Continued 

Terminated 

Valid Count, 

cc False 

Valid Count, 

ccTrue 

Expired 

Count 

Instruction 

Size 

op Dn, Dn 

op M, M * 

ADDX 

Byte, Word 

4(1 /O) 

18(3/1) 

22(2/1) 

28(4/1) 

26(4/1) 

Long word 

6(1 /O) 

30(5/2) 

32.(4/2) 

38 (6 / 2) 

36(6/2) 

CMPM 

Byte, Word 

- 

12(3/0) 

14(2/0) 

20 (4/0) 

18(4/0) 

Long word 

- 

20 (5/0) 

24 (4/0) 

30 (6/0) 

26(6/0) 

SUBX 

Byte, Word 

4(1/0) 

18(3/1) 

22(2/1) 

28(4/1) 

26(4/1) 

Long word 

6(1 /O) 

30 (5/2) 

32(4/2) 

38 (6/2) 

36(6/2) 

ASCD 

Byte 

6(1/0) 

18(3/1) 

24 (2/1) 

30(4/1) 

28(4/1) 

SBCD 

Byte 

6(1/0) 

18(3/1) 

24 (2/1) 

30(4/1) 

28(4/1) 


Source and destination ea is (An) -f for CMPM and — (An) for all others. 


F.12 MISCELLANEOUS INSTRUCTION EXECUTION TIMES 

Table F.18 indicates the number of clock periods for the following miscellaneous 
instructions. The number of bus read and write cycles is shown in parenthesis as 
(r/w). The number of clock periods plus the number of read and write cycles must be 
added to those of the effective address calculation where indicated. 
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Table F.18 Miscellaneous Instruction Execution Times 


Instruction 

Size 

Register 

Memory 

Register** 

—> 

Destination 

Source**-^ 

Register 

ANDI to CCR 

- 

16(2/0) 

- 

- 

- 

ANDl to SR 

- 

16(2/0) 

- 

- 

- 

CHK 

- 

8(1/0) + 


- 

- 

EORI to CCR 

- 

16(2/0) 

- 

- 

- 

EORI to SR 

- 

16(2/0) 

- 

- 

- 

EXG 

- 

6(1/0) 

- 

- 

- 

EXT 

Word 

4(1/0) 

- 

- 

- 

Long word 

4(1/0) 

- 

- 

- 

LINK 

- 

16(2/2) 

- 

_ 

- 

MOVE from CCR 

- 

4(1/0) 

8(1/1) + * 

_ 

- 

MOVE to CCR 

- 

12(2/0) 

12(2/0) + 

- 

- 

MOVE from SR 

- 

4(1/0) 

8(1/1) + * 

- 

- 

MOVE to SR 

- 

12 (2/0) 

12(2/0) + 

- 

- 

MOVE from USP 

- 

6(1/0) 

- 

- 

- 

MOVE to USP 

- 

6(1/0) 

- 

- 

- 

MOVEC 

- 

- 

- 

10(2/0) 

12(2/0) 

MOVEP 

Word 

- 

- 

16(2/2) 

16(4/0) 

Long word 

- 

- 

24(2/4) 

24(6/0) 

NOP 

- 

4(1/0) 

- 

- 

- 

ORI to CCR 

- 

16(2/0) 

- 

- 

- 

ORI to SR 

- 

16(2/0) 

- 

- 

- 

RESET 

- 

130(1/0) 

- 

- 

- 

RTD 

- 

16(4/0) 

- 

- 

- 

RTE 

Short 

24(4/0) 

- 

- 

- 

Long word, Retry Read 

112(27/10) 

- 

- 

- 

Long word, Retry Write 

112(26/1) 


- 

- 

Long word, No Retry 

110(26/0) 

- 

- 

- 

RTR 

- 

20 (5/0) 

- 

- 

- 

RTS 

- 

16(4/0) 

- 

- 

- 

STOP 

- 

4 (0/0) 

- 

- 

- 

SWAP 

- 

4(1/0) 

- 

- 

- 

TRAPV 

- 

4(1/0) 

- 

- 

- 

UNLK 

- 

12(3/0) 

- 

- 

- 


+ : add effective address calculation time. 

* : use non-feching effective address calculation time. 

* * : Source or destination is a memory location for the MOVEP instruction and 
a control register for the MOVEC instruction. 
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F.13 EXCEPTION PROCESSING EXECUTION TIMES 

Table F.19 indicates the number of clock periods for exception processing. The 
number of clock periods includes the time for all stacking, the vector fetch, and the 
fetch of the first two instruction words of the handler routine. The number of bus 
read and write cycles is shown in parenthesis as (r/w). 


Table F.19 Exception Processing Execution Times 


Exception 


Address Error 

126(4/26) 

Breadpoint Instruction* 

42 (5/4) 

Bus Error 

126(4/26) 

CHK Instruction* 

44(5/4) + 

Divide By Zero 

42(5/4) + 

Illegal Instruction 

38(5/4) 

Interrupt* 

46(5/4) 

MOVEC, Illegal Control Register** 

46(5/4) 

Privilege Violation 

38(5/4) 

Reset*** 

40(6/0) 

RTE, Illegal Format 

50 (7/4) 

RTE, Illegal Revision 

70(12/4) 

Trace 

38(4/4) 

TRAP Instruction 

38(4/4) 

TRAPV Instruction 

38(5/4) 


*** 


Add effective address calculation time. 

The interrupt acknowledge and breakpoint cycles are assumed to take four clock periods. 
Indicates maximum value. _ _ 

Indicates the time from when RESET and HALT are first sampled as negated to when 
instruction execution starts. 
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APPENDIX G TMP 68010 LOOP MODE OPERATION 

The TMP68010 has several features that provide efficient execution of program 
loops. One of these features is the DBcc looping primitive instruction. The DBcc 
instruction operates on three operands, a loop counter, a branch condition, and a 
branch displacement. When the DBcc is executed in loop mode, the contents of low 
order word of the register specified as the loop counter is decremented by one and 
compared to minus one. If equal to minus one, the result of the decrement is placed 
back into the count register and the next sequential instruction is executed, 
otherwise the condition code register is checked against the specified branch 
condition. If the condition is true, the result of the decrement is discarded and the 
next sequential instruction is executed. Finally, if the count register is not equal to 
minus one and the branch condition is false, the branch displacement is added to the 
program counter and instruction execution continues at that new address. Note that 
this is slightly different than non-looped execution; however, the results are the 
same. 

An example of using the DBcc instruction in a simple loop for moving a block of 
data is shown in Figure G.l. In this program, the block of data 'LENGTH' words 
long at address 'SOURCE' is to be moved to address 'DEST' provided that none of 
the words moved are equal to zero. When the effect of instruction prefetch on this 
loop is examined it can be seen that the bus activity during the loop execution would 
be: 

1. Fetch the MOVE.W instruction, 

2. Fetch the DBEQ instruction, 

3. Read the operand where AO points, 

4. Write the operand where A1 points, 

5. Fetch the DBEQ branch displacement, and 

6. If loop conditions are met, return to step 1. 


LEA 

SOURCE, AO 

Load A Pointer To Source Data 

LEA 

DEST, A1 

Load A Pointer To Destination 

MOVE.W 

^LENGTH, DO 

Load The Counter Register 

MOVE.W 

(A0)+, (Al)+ 

Loop To Move The Block Of Data 

DBEQ 

DO, LOOP 

Stop If Data Word Is Zero 


Figure G.l DBcc Loop Mode Program Example 
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During this loop, five bus cycles are executed; however, only two bus cycles 
perform the data movement. Since the TMP68010 has a two word prefetch queue in 
addition to a one word instruction decode register, it is evident that the three 
instruction fetches in this loop could be eliminated by placing the MOVE.W word in 
the instruction decode register and holding the DBEQ instruction and its branch 
displacement in the prefetch queue. The TMP68010 have the ability to do this by 
entering the loop mode of operation. During loop mode operation, all opcode fetches 
are suppressed and only operand reads and writes performed until an exit loop 
condition is met. 

Loop mode operation is transparent to the programmer, with only two conditions 
required for the TMP68010 to enter the loop mode. First, a DBcc instruction must be 
executed with both branch conditions met and a branch displacement of minus four; 
which indicates that the branch is to a one word instruction preceding the DBcc 
instruction. Second, when the processor fetches the instruction at the branch 
address, it is checked to determine whether it is one of the allowed looping 
instructions. If it is, the loop mode is entered. Thus, the single word looped 
instruction and the first word of the DBcc instruction will each be fetched twice 
when the loop is entered; but no instruction fetches will occur again until the DBcc 
loop conditions fail. 

In addition to the normal termination conditions for a loop, there are several 
conditions that will cause the TMP68010 to exit loop mode operation. These 
conditions are interrupts, trace exceptions, reset errors, and bus errors. Interrupts 
are honored after each execution of the DBcc instruction, but not after execution of 
the looped instruction. If an interrupt exception occurs, loop mode operation is 
terminated and can be restarted on return from the interrupt handler. If the T bit is 
set, trace exceptions will occur at the end of both the loop instruction and the DBcc 
instruction and thus loop mode operation is not available. Reset will abort all 
processing, including the loop mode. Bus errors during the loop mode will be treated 
the same as in normal processing; however, when the RTE instruction is used to 
continue the execution of the looped instruction, the three word loop will not be re¬ 
fetched. 

The loopable instructions available on the TMP68010 are listed in Table G.l. 
These instructions may use the three address register indirect modes to form one 
word looping instructions; (An), (An) +, and —(An). 
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Table G.l TMP68010 Loopable Instructions 


Opcodes 

Applicable 

Addressing Modes 

MOVE [BWL] 

(Ay)to(Ax) -(Ay)to(Ax) 
(Ay)to(Ax)+ -(Ay)to(Ax)+ 
(Ay)to-(Ax) -(Ay)to-(Ax) 
(Ay)+to(Ax) Xy to (Ax) 
(Ay)+to (Ax)+Xy to (Ax)+ 
(Ay)+to -(Ax) 

ADD [BWL] 

AND [BWL] 

CMP [BWL] 

OR [BWL] 

SUB [BWL] 

(Ay) to Dx 
(Ay)+to Dx 
- (Ay) to Dx 

ADDA [WL] 
CMPA[WL] 
SUBA [WL] 

(Ay) to Ax 
- (Ay) to Ax 
(Ay)+to Ax 

ADD [BWL] 

AND [BWL] 

EOR [BWL] 

OR [BWL] 

SUB [BWL] 

Dx to (Ay) 

Dx to (Ay)+ 

Dx to -(Ay) 


Opcodes 

Applicable 
Addressing Modes 

ABCD [B] 

-(Ay) to -(Ax) 

ADDX [BWL] 


SBCD [B] 


SUBX [BWL] 


CMPM [BWL] 

(Ay)+ to (Ax)+ 

CLR [BWL] 

(Ay) 

NEC [BWL] 

(Ay)+ 

NEGX[BWL] 

-(Ay) 

NOT [BWL] 


TST [BWL] 


NBCD[B] 


ASL [W] 

(Ay) by 

ASR [W] 

{l\y)+ by 

LSL [W] 

-(Ay) by #1 

LSR [W] 


ROL [W] 


ROR [W] 


ROXL [W] 


ROXR [W] 



Note : [B, W, or L] indicate an operand size of byte, word or long word. 
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